目录

一、vue页面结构及其常用属性参考

1.页面结构

2.span栅格占据列数,通过基础的 24 分栏,迅速简便地创建布局。

3.作用域插槽定义

4.div 中表单常用属性

        rules常用配置(在return模块中配置该属性)

        dialogVisible设置为false,默认不可见(在return模块中配置该属性)

        closeDialog 设置关闭时重置表格数据(在methods中设置)

5.分页设置

6.常用校验规则

7.VUE过滤器用法

        1)过滤器的定义

        2)过滤器的使用

二、Vue中常用ajax参考

1.查找

2.新增

3.修改

4.删除

5.分类删除


一、vue页面结构及其常用属性参考

1.页面结构

<template>
  <div>
    
  </div>
</template>
<script>

  export default {
    data(){
      
      }

    return {
        
    },
    methods: {
      
    }
  }
</script>

<style lang="less" scoped>

</style>

2.span栅格占据列数,通过基础的 24 分栏,迅速简便地创建布局。

<!-- 定义栅格的一行 :gutter="20"定义行间距   :span="9" 占位符  -->
<el-row :gutter="20">
    <el-col :span="9"> </el-col>
    <el-col :span="4"> </el-col>
</el-row>

3.作用域插槽定义

<!-- slot-scope="scope" 定义作用域插槽 展现数据    scope.row展现行级元素 -->
<el-table-column label="操作">
    <template slot-scope="scope">
       <el-button  @click="updateUserBtn(scope.row)"> </el-button>
    </template>
</el-table-column>

4.div 中表单常用属性

<!-- 编辑用户新增对话框 visible.sync 控制对话框的显示-->
<el-dialog title="添加用户" :visible.sync="dialogVisible" width="50%" @close="closeDialog">

<!-- 对话框主体区域 定义用户提交表格  关于表单数据提交参数说明
          model: 表示需要提交的数据
          rules: 表单数据校验规则
          ref:   为form表单对象定义名称 方便以后调用,(例:axios中校验用)
      -->
    <el-form :model="addUserModel" :rules="rules" ref="addUserRef" label-width="100px" 
     class="demo-ruleForm">
        <el-form-item label="用户名" prop="username">
          <el-input v-model="addUserModel.username"></el-input>
        </el-form-item>
        .....
    </el-form>
<!-- 对话框底部区域 -->
    <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="addUserBtn">确 定</el-button>
    </span>
</el-dialog>

        rules常用配置(在return模块中配置该属性)

rules: {
    username: [
           { required: true, message: '请输入用户名', trigger: 'blur' },
           { min: 3, max: 30, message: '长度在 3 到 30 个字符', trigger: 'blur' }
           ],
           ......
        }

        dialogVisible设置为false,默认不可见(在return模块中配置该属性)

dialogVisible: false,

        closeDialog 设置关闭时重置表格数据(在methods中设置)

closeDialog(){
        //重置表格数据
        this.$refs.addUserRef.resetFields()
      },

5.分页设置

<!-- 定义分页组件 关于分页插件的属性说明
       1.@size-change 如果分页中每页实现的条数发生变化 则会触发这个该事件
       2.@current-change 当页数发生改变时,触发该函数
       3.current-page 当前选中的页
       4.page-sizes   页面数据展现的选项
       5.page-size    默认选中的页数
       6.layout    分页中展现的数据种类
       7.total     记录总数
       -->
</el-table>
    <el-pagination
         @size-change="handleSizeChange"
         @current-change="handleCurrentChange"
         :current-page="queryInfo.pageNum"
         :page-sizes="[5, 10, 20, 40]"
         :page-size="queryInfo.pageSize"
         layout="total, sizes, prev, pager, next, jumper"
         :total="total">
    </el-pagination>
</el-card>

6.常用校验规则

data(){
      //校验邮箱规则 rule校验规则   value校验的数据   callback回调函数
      const checkEmail = (rule, value, callback) => {
        //定义邮箱的正则表达式  JS中用/来表示正则表达式的开始和结束
        const emailRege = /^[a-zA-Z0-9-_]+@[a-zA-Z0-9-_]+\.[a-zA-Z0-9-_]+$/
        //正则表达式语法校验  test(xx) 校验成功 返回true  校验失败返回false
        if (emailRege.test(value)) {
          //表示邮箱合法 正确返回
          return callback()
        }
        callback(new Error('请填写正确的邮箱地址'))
      }

      //校验手机号的邮箱规则
      const checkPhone = (rule, value, callback) => {

        //定义校验手机号的正则语法
        const phoneRege = /^1[3456789][0-9]{9}$/
        if (phoneRege.test(value)) {

          return callback()
        }
        callback(new Error('请填写正确的手机号'))

      }

      const checkPassword = (rule, value, callback) => {
        if(this.addUserModel.password !== value) return callback(new Error('2次密码输入不一致'))
        //否则校验成功
        callback()
      }

7.VUE过滤器用法

        解决商品价格计算不精确问题,一般会将商品价格先放大100倍,在缩小100倍,保留小数点后两位。

        1)过滤器的定义

        由于过滤器是全局变量,写在main.js中

/* 定义过滤器
    1.参数: 将|左侧的数据,当作参数传递给函数.
    2.返回值: 必须添加返回值!!!
    Vue.filter("过滤器名称",过滤器动作函数(参数){

    })

 */
Vue.filter("priceFormat",function(price){

    return (price / 100).toFixed(2)
})

        2)过滤器的使用

        参数: 将  |  左侧的数据,当作参数传递给函数.

<!-- 使用过滤器 在main.js中定义过滤器 -->
        <el-table-column prop="price" label="价格(元)" width="80px">
          <template slot-scope="scope">
 <!--  将price当做参数,传给priceFormat  -->
            {{scope.row.price | priceFormat}}  
          </template>
        </el-table-column>

二、Vue中常用ajax参考

在main.js 中定义全局的axios变量 :Vue.prototype.$http = axios

1.查找

async getUserList(){
        const {data: result} = await this.$http.get('/user/list',{
           params: this.queryInfo
        })
        if(result.status !== 200) return this.$message.error("用户列表查询失败")
        this.userList = result.data.rows
        this.total = result.data.total
        
      }

2.新增

addUserBtn(){
        //校验用户数据
        this.$refs.addUserRef.validate(async valid => {
          //如果校验失败 则停止数据
          if(!valid) return

          const {data: result} =
              await this.$http.post('/user/addUser',this.addUserModel)
          if(result.status !== 200) return this.$message.error("用户新增失败")
          this.$message.success("用户新增成功")
          //关闭对话框
          this.dialogVisible = false
          //重新获取用户列表
          this.getUserList()

        })
      },

3.修改

updateUser(){
        //1.预校验数据
        this.$refs.updateUserRef.validate(async valid => {
           if(!valid)  return this.$message.error("表单验证没有通过")
           //根据接口文档要求封装数据
           let user = {}
           user.id = this.updateUserModel.id
           user.phone = this.updateUserModel.phone
           user.email = this.updateUserModel.email
           const {data: result} = await this.$http.put(`/user/updateUser`,user)
           if(result.status !== 200) return this.$message.error("用户修改失败")
           this.$message.success("用户更新成功")
           this.updateDialogVisible = false
           this.getUserList()
        })
      },

4.删除

实现用户信息删除 ,注意使用模版字符串 ES6中提出的新用法 ${key},使用反引号包裹( ` ** ` )

async deleteUser(user){
         //1.消息确认框
         const result =  await this.$confirm('此操作将永久删除 '+user.username+', 是否继续?',             
         '提示', {
                   confirmButtonText: '确定',
                   cancelButtonText: '取消',
                   type: 'warning'
                 }).catch(error => error)

         //如果确认  confirm  如果取消 cancel
         if(result !== 'confirm'){
            return this.$message.info("删除取消")
         }
         const {data: result2} = await this.$http.delete(`/user/${user.id}`)
         if(result2.status !== 200) return this.$message.error("删除失败")
         this.$message.success("删除成功")
         //重新加载 数据
         this.getUserList()
      }
    }

5.分类删除

deleteItemCatBtn(itemCat) {
        //删除商品分类信息,如果为父级节点则需要删除所有的子级信息
        this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        }).then(async () =>{
          //传递分类id
          const {data: result} = await this.$http.delete("/itemCat/deleteItemCat",{params:{id:itemCat.id,level:itemCat.level}})
          if(result.status !== 200) return this.$message.error("删除商品分类失败")
          this.$message.success("删除数据成功")
          //删除成功之后,刷新页面数据
          this.findItemCatList()
        }).catch(() => {
          this.$message({
            type: 'info',
            message: '已取消删除AAAAAAA'
          });
        });
        }
    }