10月12学习笔记

1.文件上传相关

1.创建文件上传页面(upload.html),从elememt组建中找到上传组件中的照片墙模版代码复制到eui模版中.其中:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <!-- import CSS -->
  <link rel="stylesheet" href="https://cdn.staticfile.org/element-ui/2.15.9/theme-chalk/index.css">
</head>
<body>
<div id="app">
  <input type="text" placeholder="说点啥" v-model="weibo.content">
  <!--action设置上传地址
  name设置上传参数的名称
  limit设置上传图片的数量
   :on-success="handleSuccess"文件上传成功调用的方法-->
  <el-upload
          action="/upload"
          name="pic"
          limit="3"
          list-type="picture-card"
          :on-success="handleSuccess"
          :on-preview="handlePictureCardPreview"
          :on-remove="handleRemove">
    <i class="el-icon-plus"></i>
  </el-upload>
  <el-dialog :visible.sync="dialogVisible">
    <img width="100%" :src="dialogImageUrl" alt="">
  </el-dialog>
  <hr>
 <input type="button" value="发布微博" @click="insert()">
</div>
</body>
<!-- import Vue before Element -->
<script src="https://cdn.staticfile.org/vue/2.6.14/vue.min.js"></script>

<script src="https://cdn.bootcdn.net/ajax/libs/axios/0.21.1/axios.min.js"></script>


<!-- import JavaScript -->
<script src="https://cdn.staticfile.org/element-ui/2.15.9/index.min.js"></script>
<script>
 let v= new Vue({
    el: '#app',
    data: function() {
      return {
        weibo:{
          content:'',
          url:'',
        },

        dialogImageUrl: '',
        dialogVisible: false
      }
    },
   methods:{
     handleRemove(file, fileList) {
       console.log(file, fileList);
       /*当删除页面中图片时触发的方法
       * 发请求删除服务器中的图片
       * file代表当前删除的图片文件
       * file.response代表上传该文件成功时服务器响应的内容(当前删除图片的路径)*/
       axios.get("/remove?url="+file.response).then(function() {
         console.log("删除服务器图片完成");
       })
     },
     handlePictureCardPreview(file) {
       this.dialogImageUrl = file.url;
       this.dialogVisible = true;
     },
     handleSuccess(response,file,fileList) {
       /*response代表服务器上传成功时响应的数据,此处的response和Axios框架发出请求得到的response不同,类似与response.data
       * file代表当前上传成功的文件
       * fileList代表上传的所有文件(是一个数组)*/
       v.weibo.url=response;
     },
     insert(){
       /*提交图片路径和描述,到数据库*/
       if(v.weibo.url==""){
         alert("请选择上传的图片");
         return;
       }
       axios.post("/insert",v.weibo).then(function (response) {
         alert("发布完成");
         location.href="/";//回到首页
       })
     }
   }
  })
</script>
</html>

<!--action设置上传地址 name设置上传参数的名称 limit设置上传图片的数量-->

在el-upload中事件绑定:on-success="handleSuccess"事件,获取

on-success文件上传成功时的钩子function(response, file, fileList)

2.在cn.tedu.boot07.controller.UploadController中,获取图片路径并存到指定文件夹中:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值