element-ui——踩坑

1、在调用this.$refs[formName].validate()时,没有反应

   排查:首先确保调用的方法已经执行了,其次打印 this.$refs[formName] 是否不为空,最后确保定义的 rules 无论如何都要返回callback函数

2、在使用 dialog 对话框时,会在对话框上面弹出一层遮罩层

解决方法:在el-dialog组件上添加属性  :modal-append-to-body="false",使用 append-to-body 可以把整个蒙版插入到body中

<el-dialog title="修改密码" :visible.sync="showForm" width="300px" :modal-append-to-body="false" append-to-body>

</el-dialog>

3、在el-table表格中,如果需要获取到当前行的所有数据,需要在<template slot-scope="scope"></template>内通过scope.row获取

<el-table
        ref="table"
        :data="searchList[0]?searchList:userListBackInfo"
        style="width: 100%"
        border
        height="810"
        highlight-current-row
        @cell-click="cellClick"
        @row-click="handleRowClick"
        @current-change="currentRowChange"
        v-loading="loading"
        :default-sort = "{prop: 'date', order: 'descending'}"
        >
        <el-table-column
            prop="address"
            align="center"
            label="送餐地址">

            <template slot-scope="scope">
              <el-popover
                placement="left"
                width="400"
                trigger="click">
                <el-table :data="addrList" class="innerTable">
                  <el-table-column width="60" property="id" label="地址ID"></el-table-column>
                  <el-table-column width="60" property="isDefault" label="是否默认"></el-table-column>
                  <el-table-column width="150" property="address" label="地址名称"></el-table-column>
                  <el-table-column width="100" property="tel" label="配送电话"></el-table-column>
                  <el-table-column width="100" property="memberuid" label="会员用户名"></el-table-column>
                </el-table>
                <el-button slot="reference" @click="getAddrList(scope.row)">查看</el-button>
              </el-popover>
            </template>
          </el-table-column>
</el-table>

4、switch开关,赋值开关状态的时候,需要转换成布尔值

5、在做深层次嵌套时,需要考虑el-input无法输入的问题,

     解决方法:在输入框绑定监听,添加监听方法,使用 this.$forceUpdate()强制刷新

<el-input v-model="selectForm.minNumber" autocomplete="off" @input="this.$forceUpdate()"></el-input>

6、在table表格,使用到表尾统计行时,当表格的高度为100%时,第一次加载表格的时候,会出现统计行被挤出可视区域的问题,当改变表格的宽高时,统计行会出现,可以在模板渲染完后重新再渲染一次,已解决这个问题

getSummaries(param) {
   this.$nextTick(() => {
     this.$refs.table.doLayout();
   });
   return ['合计']
}

7、在使用表单验证器的时候,验证器字段需要与输入框 v-model 绑定的字段一致,否则校验器无法获取到 value 值

// prop与el-input中v-model绑定的字段需要一致
<el-form-item label="扣减的数量" prop="quantity">
   <el-input v-model="subtractMealTicketForm.quantity" clearable ></el-input>
</el-form-item>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,让我们来一步步实现这个功能。 首先,我们需要安装 Element UI,可以通过 npm 安装: ``` npm install element-ui --save ``` 然后在 main.js 中引入并使用: ```js import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` 接下来,我们来实现时间线组件。可以在组件中使用 el-timeline 和 el-timeline-item 组件,代码如下: ```html <template> <el-timeline> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> </el-timeline> </template> ``` 其中,list 是传入组件的数据,包含每个时间点的内容和时间信息。 接着,我们来实现自动滚动功能。可以通过监听 el-timeline 的 scroll 事件,将 el-timeline 的 scrollTop 设置为最大值,让其自动滚动到底部。代码如下: ```html <template> <el-timeline ref="timeline" @scroll="handleScroll"> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> </el-timeline> </template> <script> export default { methods: { handleScroll() { const timelineEl = this.$refs.timeline.$el timelineEl.scrollTop = timelineEl.scrollHeight } } } </script> ``` 然后,我们来实现无限滚动和动态加载功能。可以使用 v-infinite-scroll 插件,通过监听 el-timeline 的滚动事件,在滚动到底部时触发加载更多数据的方法。代码如下: ```html <template> <el-timeline ref="timeline" @scroll="handleScroll" v-infinite-scroll="loadMore" infinite-scroll-disabled="loading" infinite-scroll-distance="10"> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> <div v-if="loading">正在加载...</div> </el-timeline> </template> <script> import { InfiniteScroll } from 'element-ui' export default { directives: { InfiniteScroll }, data() { return { list: [], // 数据列表 loading: false // 是否正在加载 } }, methods: { // 加载数据 loadMore() { if (this.loading) { return } this.loading = true // 模拟异步加载数据 setTimeout(() => { const newData = [{ time: '2021-08-01', content: '新的内容' }] this.list = this.list.concat(newData) this.loading = false }, 1000) }, // 滚动事件 handleScroll() { const timelineEl = this.$refs.timeline.$el if (timelineEl.scrollTop === 0) { this.loadMore() } } } } </script> ``` 在上面的代码中,我们使用了 element-ui 中的 InfiniteScroll 指令来实现无限滚动功能。同时,我们在 el-timeline 中添加了 infinite-scroll-disabled 和 infinite-scroll-distance 属性,分别用于控制是否禁用无限滚动和触发加载更多数据的距离。 现在我们已经完成了 element-ui 的时间线组件 + 自动滚动 + v-infinite-scroll 无限滚动 + 动态加载功能的实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值