element ui的time时间和table表格

 <el-date-picker v-model="value1" align="right" type="date" placeholder="选择日期" value-format="yyyy-MM-dd" @change="changeDate">
            </el-date-picker>
            <el-date-picker v-model="datetime" type="datetime" placeholder="选择日期" value-format="yyyy-MM-dd HH:mm:ss" @change="changeDate">
            </el-date-picker>

年月日,时分秒,这种日期组件是我们经常会用到的,我们很多场景都会用到这个组件,所以今天来说一下这两个东西!这里最重要的就是要记住这两个格式,

value-format="yyyy-MM-dd HH:mm:ss"

value-format="yyyy-MM-dd"

剩下的都可以迎刃而解了~

接下来我们说一下table表格~

首先,我们先写一个el-table标签,这个就是表头,然后绑定一个data,接着写一个el-table-column标签,这个表示一列,然后给上label属性,这个属性就是代表这列叫什么名字。

<el-table :data="tableData">

                <el-table-column label="名称" ></el-table-column>

 </el-table>

 tableData:[

            {

                    name:'小刘',

                    address:'中国',

                    age:20

                },  {

                    name:'小高',

                    address:'中国',

                    age:23

                },

            ]

这个数据是一个数组对象,然后我们有name,address,age这三列,那么我们肯定需要三个el-table-column标签。还有一个重要的属性,叫prop,这个代表,哪一列,要放什么数据,就绑定什么属性

 <el-row style="margin: 20px 0;">
            <el-table :data="tableData">
                <el-table-column label="名称" prop="name"></el-table-column>
                <el-table-column label="国籍" prop="address"></el-table-column>
                <el-table-column label="年龄" prop="age"></el-table-column>
            </el-table>
        </el-row>

这样就绑定了三个属性,都会显示在下面了
还可以设置表头的样式,通过 :header-cell-style就可以

 <el-row style="margin: 20px 0;">
            <el-table stripe :data="tableData" border :header-cell-style="{background:'red',fontSize:'20px'}">
                <el-table-column label="名称" prop="name"></el-table-column>
                <el-table-column label="国籍" prop="address"></el-table-column>
                <el-table-column label="年龄" prop="age"></el-table-column>
            </el-table>
        </el-row>

我们还会遇到很多的实际操作,比如:我们最后一列要变成按钮,这个操作也是经常用的!

<el-row style="margin: 20px 0;">
            <el-table stripe :data="tableData" border :header-cell-style="{background:'red',fontSize:'20px'}">
                <el-table-column label="名称" prop="name"></el-table-column>
                <el-table-column label="国籍" prop="address"></el-table-column>
                <el-table-column label="年龄" prop="age"></el-table-column>
                <el-table-column label="操作">
                    <template v-slot="scope">
                        <el-button type="primary" @click="edit(scope.row)">编辑</el-button>
                    </template>
                </el-table-column>
            </el-table>
        </el-row>


  methods:{
        edit(row){
            alert(row.name)
        }
    }

我们首先更改最后一列,变成操作,然后用v-slot插槽,接着写一个按钮,在按钮上绑定一个点击事件,然后再点击事件中,将行数据传入,最后在方法中写弹出事件,弹出名字即可
 

v-slot 指令的使用场景包括但不限于以下几种:

  • 在组件中使用插槽,将父组件中的内容传递给子组件。
  • 在子组件中使用具名插槽,根据插槽名称渲染不同的内容。
  • 在子组件中使用作用域插槽,将子组件中的数据传递到父组件中进行渲染。

我们再来美化一下弹窗,哈哈哈哈

methods:{
        edit(row){
            // alert(row.name)
            this.$confirm('这是个什么玩意?','提示',{
                type:'warning'
            }).then(res=>{
                this.$message.success("ok我点击了确认")
            }).catch(()=>{
                this.$message.warning("ok我点击了取消")

            })
        }
    }

这样点击edit的时候就会弹出弹窗,美观很多

Element UI是一个基于Vue 2的开源UI组件库,它提供了一系列易于使用的表单、数据展示布局组件。要在Element UI表格(el-table)中实现实时修改时间的功能,你可以使用内置的编辑列(editable column)或者自定义单元格模板。 1. **使用内置编辑列**: Element UI的`el-table-column`有一个`formatter`属性,你可以将其设置为一个函数,该函数接收当前行的数据作为参数,然后返回一个可以编辑的时间输入元素。当用户完成修改并提交时,你需要监听表单的事件更新数据。 ```html <template> <el-table :data="tableData" @edit="handleEdit"> <!-- ... --> <el-table-column type="timestamp" label="时间" prop="time" editable /> <!-- ... --> </el-table> </template> <script> export default { methods: { handleEdit(row) { // 获取修改后的值并处理 const newRow = { ...row, time: new Date() }; // 示例:假设这里将时间设为当前时间 // 更新表格数据 this.tableData[row.index] = newRow; } }, data() { return { tableData: [ { time: '原时间', ... } // 表格数据 ] }; } } </script> ``` 2. **自定义单元格模板**: 如果需要更复杂的编辑功能,你可以使用自定义模板来创建完整的表单组件。创建一个组件,如`TimeEditor.vue`,并在`template`里包含日期选择器或其他时间输入控件。在表格中使用这个组件: ```html <template> <el-table-column label="时间" prop="time" cell-template="components/TimeEditor.vue" ></el-table-column> </template> <script> import TimeEditor from '@/components/TimeEditor.vue'; export default { components: { TimeEditor, }, // ...其他代码 }; </script> ``` 在`TimeEditor.vue`组件里,同样处理用户的输入并更新数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值