【ajax实战05】文章封面发布

一:实现效果

二:实现步骤

1 准备标签结构和样式

html结构样式

javascript 复制代码
<div class="cover">
       <label for="img">封面:</label>
       <label for="img" class="place">+</label>
       <input class="img-file" type="file" name="img" id="img" hidden="">
       <img class="rounded">
 </div>

2 获取提交的文件保存在表单对象(FormData)中(服务器要求)

3 单独上传图片并得到图片url地址

4 回显并切换img标签展示(隐藏+号上传标签)

javascript 复制代码
document.querySelector('.img-file').addEventListener('change', async e => {
  //从FileList对象中选取属性名为0的对象
  const file = e.target.files[0]
  console.log(file);
  //  *  2.2 选择文件并保存在 FormData
  //可以使用FormData对象携带表单数据
  const formData = new FormData()
  formData.append('image', file)
  console.log(formData);
  //利用async和await等待axios成功返回的结果
  const result = await axios({
    url: '/v1_0/upload',
    method: 'post',
    data: formData
  })
    //  *  2.3 单独上传图片并得到图片 URL 网址
  // console.log(result);
  const imgUrl = result.data.url
  document.querySelector('.rounded').src = imgUrl
  document.querySelector('.rounded').classList.add('show')
  document.querySelector('.place').classList.add('hide')
})

当点击img更换图片

javascript 复制代码
//点击img可以重新切换封面
// 思路:img点击=》用JS方式触发文件选择元素(input标签),用click事件方法模拟点击input
document.querySelector('.rounded').addEventListener('click', () => {
  document.querySelector('.img-file').click()
})

注意:图片地址临时存储在img标签上,并未和文章关联保存

相关推荐
YaeZed2 分钟前
Vue3-插槽slot
前端·vue.js
杨进军4 分钟前
如何实现划词效果
前端·javascript
前端老爷更车5 分钟前
esp32 小智AI 项目
前端
destinying5 分钟前
五年前端,我凌晨三点的电脑屏幕前终于想通了这件事
前端·javascript·vue.js
想学后端的前端工程师6 分钟前
【React Hooks深度实战指南:从原理到最佳实践】
前端·react.js·前端框架
elangyipi12326 分钟前
前端面试题:如何减少页面重绘跟重排
前端·面试·html
想学后端的前端工程师32 分钟前
【前端安全防护实战指南:从XSS到CSRF全面防御】
前端·安全·xss
czlczl2002092537 分钟前
基于 Spring Boot 权限管理 RBAC 模型
前端·javascript·spring boot
未来之窗软件服务38 分钟前
幽冥大陆(六十七) PHP5.x SSL 文字加密—东方仙盟古法结界
服务器·前端·ssl·仙盟创梦ide·东方仙盟
小北方城市网1 小时前
第 10 课:Node.js 后端企业级进阶 —— 任务管理系统后端优化与功能增强(续)
大数据·前端·vue.js·ai·性能优化·node.js