位置: IT常识 - 正文

vue3+Naive UI数据表格基本使用方式(vue ui怎么用)

编辑:rootadmin
vue3+Naive UI数据表格基本使用方式 一、基础使用方式

推荐整理分享vue3+Naive UI数据表格基本使用方式(vue ui怎么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue ui怎么用,vue ui怎么用,vue3 $on,vue的ui,vue3.0 ui库,vue3 $on,vue 3.1,vue3.0 ui库,内容如对您有帮助,希望把文章链接给更多的朋友!

1.引入表格及数据

<-- 表格标签 --><n-data-table :bordered="false" :single-line="false" :columns="tableHead" :data="tabeldata"/>//表头数据 一个对象表示一列 titel是每一列的名字 key是对应的字段名 可在对象类写每一列的宽度居中方式等样式const tableHead = ref([ { title: '姓名', key: 'name', width: 300, align: 'center', }, { title: '年龄', key: 'age' }, { title: '地址', key: 'address' }, { title: '标签', key: 'tags', render(row) { const tags = row.tags.map((tagKey) => { return h( NTag, { style: { marginRight: '6px' }, type: 'info', bordered: false }, { default: () => tagKey } ) }) return tags } }, { title: '状态', key: 'status' }, { title: '操作', key: 'actions', //添加按钮时必须有模板组件,将按钮信息以参数形式传到组件中,在组件中写相关样式 或 使用naive ui提供的组件 render(record) { return [ h(NButton, { //NButton是naive ui提供的按钮组件模板,需要引入 import { NTag, NButton, } from 'naive-ui' text: true, style: { marginRight: '10px' }, onClick: () => viewdetail(record) }, { default: () => '详情' } ), h(NButton, { text: true, onClick: () => deletedata(record) }, { default: () => '删除' } ) ] } }])//表格数据const tabeldata = ref([ { key: 0, name: 'John Brown', age: 32, address: 'New York No. 1 Lake Park', status: '0', tags: ['nice', 'developer'] }, { key: 1, name: 'Jim Green', age: 42, address: 'London No. 1 Lake Park', status: '1', tags: ['wow'] }, { key: 2, name: 'Joe Black', age: 32, address: 'Sidney No. 1 Lake Park', status: '0', tags: ['cool', 'teacher'] }])

 这样一个基础表格就渲染出来了

 二、修改操作按钮等标签样式

项目中可能会修改操作按钮、标签等元素样式修改,以按钮为例,提供以下方式(需要注意的是,在naive ui数据表格中使用按钮、标签等元素必须提供HTML元素模板,否则渲染出错,所谓模板其实就是一个组件)

1.naive ui提供的模板{ title: '操作', key: 'actions', //使用naive ui提供的按钮模板,需要引入按钮模板 import { NButton } from 'naive-ui' render(record) { return [ h(NButton, {//可在里面写按钮样式 text: true, style: { marginRight: '10px' }, onClick: () => viewdetail(record)//点击按钮后的回调 }, { default: () => '详情' }//按钮显示名称 ), h(NButton, { info: true, onClick: () => deletedata(record) }, { default: () => '删除' } ) ] } }

这样就可以渲染出按钮

2.自定义按钮模板 

项目中使用naive提供的模板可能满足不了需求,这时可以使用自定义模板(组件)

①定义一个组件文件

<template> <div> <template v-for="(action, index) in getActions" :key="index"> <n-button v-bind="action" style="margin-right: 10px;" text> {{ action.label }} </n-button> </template> </div></template><script lang="ts">import { defineComponent, PropType, computed, toRaw, onMounted } from 'vue';export default defineComponent({ props: { actions: { type: Object, default: null, required: true, }, }, setup(props) { onMounted(() => { // console.log(props); }) const getActions = computed(() => { return props.actions }); return { getActions, }; },});</script>

②页面中引入该组件并使用

import ActionTemplate from '@/components/ActionTemplate.vue'{ title: '操作', key: 'actions', render(record) { return h(ActionTemplate,//使用按钮组件 { actions: [//通过props传参将actions传给按钮组件(对应样式也可传递过去) { label: '删除', onClick: deletedata.bind(null, record), }, { label: '详情', onClick: viewdetail.bind(null, record), }, ], } ) } }vue3+Naive UI数据表格基本使用方式(vue ui怎么用)

这样就可以渲染出按钮

 三、根据数据显示不同内容

项目中可能会根据后台返回的数据在表格中显示不同内容,可以通过以下方式实现

{ title: '状态', key: 'status', className: 'stustatus', render(record) { let text = '' if (record.status == '0') { text = '在读' } else if (record.status == '1') { text = '毕业' } return h('span', text)//这种渲染方式与渲染按钮操作一样必须提供元素模板,但是这里直接这样写'span'就可以,而渲染操作按钮的时候写'n-button'却会报错,我也搞不懂,有了解的伙伴可以解释一下 } },

最后就可以根据数据渲染不同内容了

 四、不同内容显示不同样式

项目中表格不同内容会显示不同的样式,提供以下方式实现

①在表格标签中加上返回样式的属性 :row-class-name="rowClassName"

<n-data-table :bordered="false" :single-line="false" :columns="tableHead" :data="tabeldata" :row-class-name="rowClassName" />

 ②定义返回类名的函数

const rowClassName = (row) => { if (row.status == '0') { return 'statusin' } return 'statusout'}

 ③在style中写不同类名对应的样式

:deep(.statusin .stustatus) { color: rgba(63, 210, 19, 0.75) !important;}:deep(.statusout .stustatus) { color: rgba(251, 8, 61, 0.75) !important;}

④在对应列的表头对象里面加入类名属性 className: 'stustatus'

{ title: '状态', key: 'status', className: 'stustatus', render(record) { let text = '' if (record.status == '0') { text = '在读' } else if (record.status == '1') { text = '毕业' } return h('span', text) } },

最后表格就渲染出来了

 我也是在最近的项目迭代中开始使用的vue3+naive ui,开发过程中也遇到很多问题,网上与naive ui相关的文章太少了,也只能看文档慢慢研究,后面也会不断地更新与naive ui相关的文章,总之多看看文档吧。以上问题如果有其他解决方法的话欢迎交流。

本文链接地址:https://www.jiuchutong.com/zhishi/287966.html 转载请保留说明!

上一篇:如何在Kaggle上利用免费Gpu训练Yolox的模型(kaggle能赚钱吗)

下一篇:常用的前端大屏 适配方案(常用的前端大屏软件)

  • 荣耀x20怎么设置字体大小(荣耀x20怎么设置骚扰电话拦截)

    荣耀x20怎么设置字体大小(荣耀x20怎么设置骚扰电话拦截)

  • 校讯通是不是只有移动才能使用

    校讯通是不是只有移动才能使用

  • 快手删作品会影响权重吗(快手删作品会影响浏览吗)

    快手删作品会影响权重吗(快手删作品会影响浏览吗)

  • 淘宝投诉撤销后还可以再次投诉吗(淘宝投诉撤销后还能再次发起投诉吗)

    淘宝投诉撤销后还可以再次投诉吗(淘宝投诉撤销后还能再次发起投诉吗)

  • 钉钉群移除如何找回(钉钉群移除还能进去吗)

    钉钉群移除如何找回(钉钉群移除还能进去吗)

  • 防尘塞对手机充电口有危害吗(防尘塞对手机有损害)

    防尘塞对手机充电口有危害吗(防尘塞对手机有损害)

  • p40怎么无线充电(p40无线充电功能在哪里设置)

    p40怎么无线充电(p40无线充电功能在哪里设置)

  • 苹果11闹钟声音大小怎么调(苹果11闹钟声音小怎么回事)

    苹果11闹钟声音大小怎么调(苹果11闹钟声音小怎么回事)

  • 苹果11充满电闪电不消失(苹果充满电闪电会消失吗)

    苹果11充满电闪电不消失(苹果充满电闪电会消失吗)

  • 腾讯会议没有声音怎么回事(腾讯会议没有声音了怎么办)

    腾讯会议没有声音怎么回事(腾讯会议没有声音了怎么办)

  • 电脑无法安装软件(电脑无法安装软件怎么回事)

    电脑无法安装软件(电脑无法安装软件怎么回事)

  • vivo抖音动态锁屏怎么设置(抖音动态怎么锁住了)

    vivo抖音动态锁屏怎么设置(抖音动态怎么锁住了)

  • 苹果抹掉数据能恢复吗(苹果抹掉数据还能用吗)

    苹果抹掉数据能恢复吗(苹果抹掉数据还能用吗)

  • vsco免费还是付费(vsco不是免费的吗)

    vsco免费还是付费(vsco不是免费的吗)

  • 电脑系统设置在哪里(电脑打开进不了系统怎么办)

    电脑系统设置在哪里(电脑打开进不了系统怎么办)

  • 苹果11支持指纹吗(苹果11支持指纹解锁吗)

    苹果11支持指纹吗(苹果11支持指纹解锁吗)

  • excel怎么在日期后面加星期几(excel怎么在日期后面加星期)

    excel怎么在日期后面加星期几(excel怎么在日期后面加星期)

  • vivoz3什么时候更新9.0系统(vivoz3什么时候官网下架)

    vivoz3什么时候更新9.0系统(vivoz3什么时候官网下架)

  • 拼多多怎么关闭消息震动(拼多多怎么关闭别人看到我买的东西)

    拼多多怎么关闭消息震动(拼多多怎么关闭别人看到我买的东西)

  • OLED和AMOLED的区别(oled和amoled屏幕哪个好)

    OLED和AMOLED的区别(oled和amoled屏幕哪个好)

  • win10如何修改硬盘格式(win10怎么改硬盘)

    win10如何修改硬盘格式(win10怎么改硬盘)

  • 手机便签文件在哪(手机便签文件在哪个文件夹)

    手机便签文件在哪(手机便签文件在哪个文件夹)

  • 窗口与对话框的区别(窗口与对话框的不同点和相同点)

    窗口与对话框的区别(窗口与对话框的不同点和相同点)

  • 公积金提取条件_有这11种情况你也可以提取(公积金提取条件和标准)

    公积金提取条件_有这11种情况你也可以提取(公积金提取条件和标准)

  • 【Matlab 六自由度机器人】运动学逆解(附MATLAB机器人逆解代码)(matlab中自由变量)

    【Matlab 六自由度机器人】运动学逆解(附MATLAB机器人逆解代码)(matlab中自由变量)

  • 2022年最新前端面试题,持续更新(2021前端热门技术解读)

    2022年最新前端面试题,持续更新(2021前端热门技术解读)

  • 小规模纳税人税收优惠2023
  • 个人接私活需要开票,可以让别的公司帮忙开票吗?
  • 零报税有风险吗
  • 2019所得税新政策
  • 甲供材能否开具增值税专用发票
  • 上一年度凭证不填可以吗
  • 发票额开多了多出的金额怎么处理?
  • 预支的采购备用金是什么
  • 建安税由谁承担
  • 亏损弥补额的年数如何计算?
  • 已认证未抵扣进项税如何做账
  • 买商品送购物券合法吗
  • 0申报的清算所得税申报表怎么填
  • 年终奖个税公式表最新
  • 非征期不能抄报
  • 会计记账凭证的填制
  • 未开票收入纳税
  • 工商注册需要提供什么
  • 1697508577
  • 一次发放数月的高温津贴如何计算个税?
  • 代扣代征税款有哪些
  • 会计人员需要承担的责任
  • BT模式建设项目怎么处理税收?
  • 回收站右键菜单修改
  • 营运资金主要包括什么
  • 开具红字发票后如何在申报表中填写?
  • 返利给客户的账务处理
  • 其他综合收益是什么意思
  • php array_search() 函数使用
  • PHP:session_module_name()的用法_Session函数
  • vue trim
  • 企业租用个人房屋
  • nginx静态文件服务器
  • 斐讯路由器怎么重置
  • php批量更新数据库
  • 可以跨城租车吗
  • 长期股权投资会减值吗
  • 该税号缺少必要信息
  • 在暴风雪中求生
  • uniapp自定义导航栏渐变
  • vue预览word加水印
  • php静态方法可以被继承吗
  • 法人借钱给公司,公司可以直接转给法人吗
  • 预收款怎么做表格
  • phpcms文档
  • 航天金税服务费280不交
  • linux下安装mysql数据库5.6源码安装,修改登录用户密码
  • 房产税的计算器
  • 一般纳税人开普票要交税几点
  • sql 附加数据库
  • 合伙企业是否需要缴纳印花税
  • 模具报价成本核算方法
  • 存货的进口关税计入成本吗
  • 一般纳税人出现以下哪些情况时,其进项税额不得抵扣( )
  • 契税在计算利润时不扣除吗
  • 企业到外地
  • 农业技术人员是什么意思
  • 会计凭证要保存多少年企业注销
  • mysql安装过程中报错
  • window放大之后怎么缩小
  • windows vista(service pack1)
  • centos怎么查看文件
  • 通过防火墙可以保证窃听到的信息毫无价值
  • Win10 Mobile/PC RS2快速预览版14926同步推送
  • Ubuntu 8.10 Server Ruby 的安装方法
  • win7系统安装的配置要求有什么
  • windows多屏显示
  • linux讲解
  • win8应用商店怎么卸载
  • Windows10系统下iis没有注册.netFrameWork4.0的原因
  • 基于jQuery中ajax的相关方法汇总(必看篇)
  • 改变的拼音
  • shell 时间运算
  • python-shell
  • 可分割项目
  • 开票系统怎么升级?
  • 上海市个人所得税计算
  • 北京顶点b128怎么样
  • 税务筹划怎么样
  • 中山税务如何预约
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设