位置: 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能赚钱吗)

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

  • win10安全模式怎么进(win10安全模式怎么取消掉)

    win10安全模式怎么进(win10安全模式怎么取消掉)

  • 荣耀x10后盖是玻璃材质吗(荣耀x10后盖玻璃不是原装)

    荣耀x10后盖是玻璃材质吗(荣耀x10后盖玻璃不是原装)

  • 合约机是什么意思(合约机是什么意思手机)

    合约机是什么意思(合约机是什么意思手机)

  • 华为nova5耳机接口在哪(华为nova5耳机接口)

    华为nova5耳机接口在哪(华为nova5耳机接口)

  • 微信正在清理需要多久(微信提示正在清理)

    微信正在清理需要多久(微信提示正在清理)

  • 手机不等号怎么打出来(手机不等号怎么输入符号)

    手机不等号怎么打出来(手机不等号怎么输入符号)

  • iphone7怎么截屏(iphone7怎么截屏视频教程)

    iphone7怎么截屏(iphone7怎么截屏视频教程)

  • 现在腾讯视频vip只能登一个了吗(现在腾讯视频VIP多少钱一个月)

    现在腾讯视频vip只能登一个了吗(现在腾讯视频VIP多少钱一个月)

  • qq免打扰能收到语音电话么(qq免打扰能收到qq语音吗)

    qq免打扰能收到语音电话么(qq免打扰能收到qq语音吗)

  • 十进制数29转换成无符号二进制数等于多少(十进制数29转换成无符号二进制数)

    十进制数29转换成无符号二进制数等于多少(十进制数29转换成无符号二进制数)

  • 抖音直播间在哪里看(抖音直播间在哪里找)

    抖音直播间在哪里看(抖音直播间在哪里找)

  • 苹果定位箭头空心和实心区别(苹果定位箭头空心的怎么弄)

    苹果定位箭头空心和实心区别(苹果定位箭头空心的怎么弄)

  • 电视能安装快手吗(电视安装快手解析包出现问题)

    电视能安装快手吗(电视安装快手解析包出现问题)

  • 怎样增加淘宝的心级(怎样增加淘宝的流量)

    怎样增加淘宝的心级(怎样增加淘宝的流量)

  • 写字板是一种什么工具(写字板是什么)

    写字板是一种什么工具(写字板是什么)

  • word一级标题怎么弄(Word一级标题怎么对齐)

    word一级标题怎么弄(Word一级标题怎么对齐)

  • 抖音怎么不显示动态了(抖音怎么不显示特效标志)

    抖音怎么不显示动态了(抖音怎么不显示特效标志)

  • 流量显示e怎么换成4g(流量符号显示e)

    流量显示e怎么换成4g(流量符号显示e)

  • 华为p30微信怎么加密(华为P30微信怎么上锁)

    华为p30微信怎么加密(华为P30微信怎么上锁)

  • 触宝电话如何去除广告(触宝电话怎样)

    触宝电话如何去除广告(触宝电话怎样)

  • 苹果手机键盘手写在哪里(苹果手机键盘手机号怎么取消)

    苹果手机键盘手写在哪里(苹果手机键盘手机号怎么取消)

  • 文件资源管理器在哪(文件资源管理器快捷键)

    文件资源管理器在哪(文件资源管理器快捷键)

  • 火山视频如何取消关注的人(怎样去掉火山视频上个人名字和号)

    火山视频如何取消关注的人(怎样去掉火山视频上个人名字和号)

  • vue3 如何实现 表格内容无缝滚动,我又写了一堆冗余代码(vue3怎么用)

    vue3 如何实现 表格内容无缝滚动,我又写了一堆冗余代码(vue3怎么用)

  • 机器学习——果蔬分类

    机器学习——果蔬分类

  • 保险公司支付的赔款计入什么科目
  • 增值税专票如何作废
  • 个体工商户可以开发票吗
  • 个体户不足征是否要交房产税
  • 饮料工业发展前景如何
  • 税收优惠有哪些类型
  • 给国外汇款交增值税吗
  • 未达账项怎么做会计分录
  • 挂靠工程如何交纳税金帐务处理?
  • 外包会计处理
  • 收到发票冲预付账款摘要怎么写
  • 汇算清缴补缴税分录
  • 应交税费账户期末借方余额反映的是
  • 企业办理跨境人民币收付需要办理名录登记吗
  • 养牛场增值税的税率是多?
  • 收代扣代缴个税手续费会计分录
  • 企业代收代支的非税收入需要缴税吗?
  • 机器人销售属于什么行业
  • 单位为员工支付医疗费
  • 未签订劳动合同工资如何给付
  • 光驱弹不出来灯也不亮
  • 待清算专户
  • 酒店没有营业执照开业犯法吗
  • 普通发票的进项票怎么做分录
  • windows10如何清理磁盘碎片
  • php远程调用
  • 苹果官网入口
  • win7怎么添加设备
  • rk3328 sdk
  • application guard
  • win10蓝牙搜索不到ps4手柄
  • ecap.exe是什么
  • 空调拆卸安装怎么找师傅
  • 企业的民间借贷怎么处理
  • 深度卷积神经网络基本结构
  • vscode的常用插件
  • 存货采购成本有余额吗
  • 再生资源回收公司会计科目
  • 解决掉发的有效方法
  • cmd 访问mysql
  • python dup函数
  • 出租营改增之前取得的有形动产
  • 微店企业店铺和个人店铺的区别
  • 代理费属于
  • 报税合同
  • 一般纳税人的建筑企业可以选择简易征收的条件
  • 季报业务活动表怎么做
  • 未确认递延所得税资产的可抵扣亏损到期年度表
  • 建设单位支付给施工单位的民工工资
  • 利息收入如何做分录
  • 产品质量问题扣款账务处理
  • 公司增资的法条
  • 租赁的生产设备计入哪个科目
  • 退回现金会计分录
  • 回收材料的好处和问题
  • 工资表里有什么
  • 零工发生事故算工伤吗
  • 固定资产领用原因
  • 融资租赁具体操作流程
  • 建立备查账的是
  • mysql使用的协议
  • 运行软件时遇到的问题
  • windows跳转列表是什么
  • ubuntu zed
  • mac系统指令集
  • 磁盘已满
  • svchos1.exe - svchos1是什么教程 有什么作用
  • win7u盘没有安全选项卡
  • win7系统无法删除打印机驱动
  • tomcat怎么启动
  • 递归怎么调用
  • linux4个主要部分
  • css中hack
  • shell 单引号中引用变量
  • nodejs cgi
  • linux中安装python的工具包
  • 新办企业税务局注册流程
  • 医保电子凭证怎么激活
  • 上市公司季报有哪些内容
  • 2022年印花税最新规定反映了什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设