2022-07-20 组件库经验 + 表单校验

一、Ant Design Vue 2.2.4

1. Tree 树形组件
(1)默认展开节点

① defaultExpandAll属性默认展开所有节点,但该属性只在 第一次渲染时生效
② 如果树形组件绑定的数据treeData,是通过 接口异步获取到的,则应当在数据获取到之后再渲染树结构。

              <a-tree
                v-if="treeData.length" // 只有绑定的数据有值了才渲染树
                checkable
                defaultExpandAll
                :tree-data="treeData"
                :replace-fields="replaceFields"
                v-model:checkedKeys="addRoleForm.permissions"
              />
2.Table 表格
(1)所有数据一行展示

① 给每一列数据一个 最小宽度 保证表头不会折叠。
② 最后一列可以 固定到右侧。

  [
    {
      title: '操作',
      dataIndex: 'action',
      key: 'action',
      slots: { customRender: 'action' },
      // 设置最小宽度
      customCell: () => {
        return {
          style: {
            'min-width': '230px',
          },
        };
      },
      fixed: 'right', // 固定到右侧
    },
  ];

③ 给表格设置 scroll="{x:true}",并用样式限制每行数据 不准换行。

          <a-table
            :row-key="(record) => record.id"
            :dataSource="dataSource"
            :columns="columns"
            :scroll="{ x: true }"
          />

④ 注意:此时的table表格如果处于flex布局中,其宽度 不能设置为 flex:1,否则表格会溢出。
⑤ 可以将宽度设置为 固定值,或者是 width: calc(100% - 100px),这里注意减号 前后的空格。
height:calc(100vh - 192px)

(2)表格排序

① columns配置项中,要有 sorter、sortOrder属性;由于sortOrder要动态变化,所以columns配置项要写在 computed计算属性中。

      const columns = computed(() => {
        return columnMethod(table.sortOrder, table.sortColumn);
      });

② 表格监听分页与排序的事件。排序改变时,根据最新的 sortColumn属性,更新 columns配置项 中的sortOrder属性,页面的箭头效果就有了。

const mySurveyColumns = (
  sortOrder: undefined | string,
  sortColumn: undefined | string,
) => {
  return [
    {
      title: '优先级',
      dataIndex: 'priority',
      key: 'priority',
      sorter: true,
      sortOrder: sortColumn === 'priority' ? sortOrder : false,
    },
]

③ 同时更新 接口请求参数 中的sortOrder和sortColumn参数,重新发送请求。

(3)element-UI 中的表格排序

columns配置项中只有sortable属性,设置为'customer'即可。排序事件触发时,不需要再手动更改属性值。

3.rowSelection属性

(1)rowSelection属性值不会动态改变,虽然绑定的值变了,但是不会作用到表格上。
(2)必须重新给 表格赋值。

二、Echarts

1.echarts图分装成组件时的注意事项

(1)dom已加载错误;
(2)获取echarts实例时,echarts所在子组件还未渲染;

      // 初始化echarts图表
      const echartsInit = () => {
        // 用echarts官方提供的getInstanceByDom获取组件实例,存放echarts的dom名称根据来自父组件
        let myChart = echarts.getInstanceByDom(document.querySelector('.' + props.el));
        if (myChart != null && myChart != '' && myChart != undefined) {
          myChart.dispose(); //解决echarts dom已经加载的报错
        }
        myChart = echarts.init(document.querySelector('.' + props.el));
        let option = {};
        myChart.setOption(option);
      };
2.大小自适应

(1)将cavans标签和最近的父元素,宽高设置为100%。
(2)onMounted时渲染图表,可能会出现宽度虽然是自己设置的100%,但内容确在横向上错位了。这是由于渲染的先后顺序导致的。可以 200毫秒后再进行图表的生成和渲染。
(3)屏幕缩放时,图表比例失调,可以监听屏幕变化,重新 myChart.setOption(option);

3.在toolTip弹框中获取更多信息

series的值可以是一个数组对象,value属性 代表的是y轴的值。

series:[1,2,3,4,5] // 常见的数组形式
// 对象数组形式
series:[
  {value:1,age:'25岁',name:'王祖贤'},
  {value:2,age:'30岁',name:'马冬梅'}
]
######4.渐变色、横轴文案竖着排、缩放功能
4.toolTip弹框引起的滚动条闪动

首次渲染时,如果存放echarts图的外层元素有滚动条,可能导致滚动条变得很长;但鼠标经过图表后,滚动条又变正常了;这是由于toolTip弹框导致的。
① 在toolTip配置项中添加confine属性。

tooltip: {
  confine: true
}

② 存放图表的外层元素,添加 overflow:hidden 属性。

三、Element-Plus

1.table表格修改了横向滚动条样式后,导致固定列下方与滚动条之间产生缝隙。
        .el-table__fixed, .el-table__fixed-right {
          height: calc(100% - 12px)!important; // 12px就是横向滚动条的高度。
        }

四、vite 打包配置

1.静态资源-图片

用v-html生成的<img />标签,在 生产环境 无法解析 assets目录 下的图片路径,可以将图片放到 public目录 下。
更多细节参考vite官方:https://vitejs.bootcss.com/guide/assets.html#importing-asset-as-url

// 将字符串中的空格替换成一张图片
original: item.original?.replace(/\s/gi,'<img src="/空格.png" alt="" class="kg" />')

// 在模板中使用v-html解析图片
<span v-html="record.original"></span>

五、表单校验ElementUI

1、表单校验的先决条件

(1)<el-form /> 标签用v-bind:model绑定数据对象。:rules绑定校验规则对象。

注意: model是表单的属性,用v-bind绑定。这跟 v-model不是一回事!!!!!!!!!

<el-form
     :model="loginForm"
     :rules="loginRules"
    />
data () {
    return {
      // 表单绑定的数据对象
      loginForm: {
        // 校验的字段
        mobile: '',
        password: ''
      },
      // 表单绑定的校验规则对象
      loginRules: {
        mobile: [],
        password:[]
    }
  },
(2) <el-form-item />标签设置 prop属性。值为 数据对象中的校验字段
<el-form-item  prop="mobile" > </el-form-item>
(3)<el-input />标签用v-model 绑定数据对象中相对应的数据。
<el-input  v-model="loginForm.mobile"> </el-input>

2、表单校验规则

规则 说明
required 如果为true,表示该字段为必填
message 当不满足设置的规则时的提示信息
pattern 正则表达式,通过正则验证值
min 当值为字符串时,min表示字符串的最小长度,当值为数字时,min表示数字的最小值
max 当值为字符串时,max表示字符串的最大长度,当值为数字时,max表示数字的最大值
trigger 校验的触发方式,change(值改变) / blur (失去焦点)两种
validator 如果配置型的校验规则不满足你的需求,你可以通过自定义函数来完成校验

格式:

loginRules:{
 校验字段:[ { },{ },{ } ]
}

 loginRules: {
        mobile: [{
          required: true, message: '手机号不能为空', trigger: 'blur'
        },
        { pattern: /^1[3-9]\d{9}$/, message: '手机号格式不正确', trigger: 'blur' }],
    }

3、自定义校验规则

(1) validator是一个函数,可以定义在 data 中。
data () {
    // 自定义校验规则
    const checkMobile = function (rulue, value, callback) {
      value.charAt(2) === '0' ? callback() : callback(new Error('错误'))
    }
    return {}
}

第一个参数代表当前的校验规则。
第二个参数代表当前被校验的数据。
第三个参数是一个回调函数。注意:无论是否通过校验,都要调用callback()函数。

(2) 自定义校验规则的函数定义好之后,要在规则对象中引用。
loginRules: {
     mobile: [{ validator: checkMobile, message: '手机号第三位必须是0', trigger: 'blur' }]
}

4、手动校验

(1)什么是手动校验

① 以上校验只能在表单失去焦点或者内容变化时触发。
② 现在希望点击登录按钮时对所有表单项进行校验。或者对部分表单进行校验。

(2)如何实现手动校验

element-ui提供了表单校验的API,我们需要通过 this.$refs 拿到表单的 DOM对象,来调用API函数。

① 给<el-form> 标签设置 ref 属性。。
② 给提交按钮绑定点击事件。
③ 在事件函数中,给表单对象绑定 validate()函数,进行校验。

methods: {
    // 手动校验
    submitForm () {
      this.$refs.loginFormRef.validate()
        .then(() => console.log('校验成功'))
        .catch((error) => console.log('校验失败'))
    }
  }
(3) element-ui 提供的表单校验API
方法名 说明 参数
validate 对整个表单进行校验的方法,参数为一个回调函数。该回调函数会在校验结束后被调用,并传入两个参数:是否校验成功和未通过校验的字段。若不传入回调函数,则会返回一个 promise Function(callback: Function(boolean, object))
validateField 对部分表单字段进行校验的方法 Function(props: array | string, callback: Function(errorMessage: string))
resetFields 对整个表单进行重置,将所有字段值重置为初始值并移除校验结果
clearValidate 移除表单项的校验结果。传入待移除的表单项的 prop 属性或者 prop 组成的数组,如不传则移除整个表单的校验结果 Function(props: array | string)

① validate可以传入一个函数作为参数,判断是否校验成功;也可以使用promise的.then().catch()方法。
② 上面使用的是promise方法。下面是传入回调函数的方法。

this.$refs.loginFormRef.validate((boolean,object)=>{} )
形参boolean的值可以判断校验是否成功;形参object时未通过校验的字段。

5、vue 结合 jsx 的动态表单校验

(1)动态生成的表单的 校验规则 rules属性,要单独写到<el-form-item>标签上。
(2)重点是 prop属性,有特殊写法。

① 其中,state.followForm 是<el-form>绑定的表单对象。
state.followForm.url是一个数组,用来存放动态生成的链接地址,数组元素就是 字符串。
prop属性直接用 数组名 url(字符串) 加上 .index(动态索引)

const state = reactive({
   followForm: {
     url: ['', ''], // 存放链接的数组,初始默认有两个输入框
   },
})
<el-form model={state.followForm}>
 {
    state.followForm.url.map((item, index) => (
        <el-form-item 
           label="数据链接:"
           prop={`url.${index}`}  // 1.注意prop属性的写法。
           rules={{ required: true, message: '请输入数据链接并以http开头', trigger: 'blur' }}  // 2.校验规则单独写。
         >
            <el-input
               v-model={state.followForm.url[index]} // 3.注意input框数据的绑定。
               onBlur={() => limitUrl(index)}
            />
         </el-form-item>
     ))
  }
</el-form>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容