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

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

  • 如何设计网店页面布局优化(如何设计自己的网页店铺)

    如何设计网店页面布局优化(如何设计自己的网页店铺)

  • 关于网上赚钱的注意事项(关于网上赚钱的作文)

    关于网上赚钱的注意事项(关于网上赚钱的作文)

  • excel表格怎么调整行高和列宽(excel表格怎么调整所有列宽)

    excel表格怎么调整行高和列宽(excel表格怎么调整所有列宽)

  • qq关闭登录保护还是需要验证(qq关闭登录保护为什么还要验证码)

    qq关闭登录保护还是需要验证(qq关闭登录保护为什么还要验证码)

  • 苹果mxmax怎么关机(关闭max)

    苹果mxmax怎么关机(关闭max)

  • 苹果怎么自定闹钟铃声(苹果怎么自定闹铃)

    苹果怎么自定闹钟铃声(苹果怎么自定闹铃)

  • 三星note11上市时间(三星note11参数配置)

    三星note11上市时间(三星note11参数配置)

  • 腾讯超级视频影视vip和腾讯视频vip区别(腾讯超级视频影视vip可以看腾讯视频嘛)

    腾讯超级视频影视vip和腾讯视频vip区别(腾讯超级视频影视vip可以看腾讯视频嘛)

  • 手机自拍照片突然模糊(手机自拍为什么突然模糊不清)

    手机自拍照片突然模糊(手机自拍为什么突然模糊不清)

  • 华为手机自带的膜是什么膜(华为手机自带的空调遥控器在哪里)

    华为手机自带的膜是什么膜(华为手机自带的空调遥控器在哪里)

  • 为什么电脑显示屏黑了但是电脑正常(为什么电脑显示微信已登录)

    为什么电脑显示屏黑了但是电脑正常(为什么电脑显示微信已登录)

  • 苹果后摄像头抖动怎么修复(苹果后摄像头抖动磁铁一吸就好了)

    苹果后摄像头抖动怎么修复(苹果后摄像头抖动磁铁一吸就好了)

  • 有网但是特别卡是为什么(有网却很卡)

    有网但是特别卡是为什么(有网却很卡)

  • 继承与多态的区别(什么是继承和多态,请举个例子说明继承和多态)

    继承与多态的区别(什么是继承和多态,请举个例子说明继承和多态)

  • 微信绑定手机号可以换几次(微信绑定手机号怎么换成别的手机号)

    微信绑定手机号可以换几次(微信绑定手机号怎么换成别的手机号)

  • 畅享10plus有nfc吗(畅享10plus有没有nfc功能)

    畅享10plus有nfc吗(畅享10plus有没有nfc功能)

  • 录屏没有声音怎么设置(录屏没有声音怎么办苹果)

    录屏没有声音怎么设置(录屏没有声音怎么办苹果)

  • word引用选项卡(word引用选项卡在哪)

    word引用选项卡(word引用选项卡在哪)

  • 小米8nfc功能在哪(小米8nfc在哪设置)

    小米8nfc功能在哪(小米8nfc在哪设置)

  • OPPOR15语音助手怎么使用(oppor15语音助手在哪里打开)

    OPPOR15语音助手怎么使用(oppor15语音助手在哪里打开)

  • 抖音删作品就不被推荐了吗(抖音删作品 不利)

    抖音删作品就不被推荐了吗(抖音删作品 不利)

  • 2016.9.20英文日期写法(2016.9.20英文日期写法缩写)

    2016.9.20英文日期写法(2016.9.20英文日期写法缩写)

  • cardreader驱动是什么(ic卡驱动)

    cardreader驱动是什么(ic卡驱动)

  • 一加7用什么屏幕(一加7用什么屏幕最好)

    一加7用什么屏幕(一加7用什么屏幕最好)

  • 三星s9可以反向充电吗(三星s9能不能反向充电)

    三星s9可以反向充电吗(三星s9能不能反向充电)

  • 契税计税依据及税率
  • 税务行政复议包括必须复议自由复议和选择复议三种类型
  • 门诊医保报销发票
  • 3%简易征收范围
  • 报验户预缴个税怎么算
  • 机器设备预付的费用计入
  • 暂估入库发票差额怎么办
  • 政府奖励企业款银行未收到会计分录
  • 增值税没达到起征标准
  • 预缴增值税怎么填表
  • 未休假报酬需要报个税吗
  • 总分机构类型怎么选
  • 文化事业建设费征收对象
  • 河道管理费入什么科目
  • 报销话费属于什么费用
  • 不得免征和抵扣的税额
  • 木制手链品种
  • 公司贷款收入如何计算
  • 进项税额加计扣除分录
  • 固定资产计算折旧时用扣除减值吗
  • 如何使用windows10自带杀毒
  • 对增值税发票开具方面有何要求?
  • 收据可以入账的文件
  • php自学
  • 安保费差额纳税是什么意思
  • php如何自定义函数
  • 员工离职后公司还用照片
  • 发票开具的有哪些原则
  • 长期股权投资资本化
  • 劳务费用 税
  • php评论盖楼
  • 股东分红应该在哪个科目
  • 论文 导论
  • nvme安装win10教程
  • Vue 3 介绍
  • php 方法
  • 账户验证是什么意思
  • 股东出资证明书范本
  • 律师事务所的日记怎么写
  • 职工教育经费年底要冲回吗
  • 债权转让收益需缴税吗
  • 企业需要交哪些税种?分别怎么交
  • 核销发生的坏账损失
  • 帝国cms灵动标签 PHP变量文章ID加减1
  • 以摊余成本计量的债权投资与以公允价值计量且其变动
  • 支付招标代理费的请示
  • 小规模不开票怎么做账
  • 公司购买不动产契税税率
  • 低值易耗品费用计入产品成本的方式有哪几种
  • 融资租赁业务如何开展
  • 先收款后给发票合法吗
  • 困难行业企业包括哪四大类
  • 股权转让,受让方的会计分录
  • 报销未收到发票怎么做账
  • 利润分配未分配利润账务处理
  • 融资租入固定资产的账务处理
  • 一般纳税人内外账
  • 固定资产发票后到怎么入账
  • 未认证的发票如何进项税转出
  • 销项负数发票如何勾选
  • 资本金账户资金允许
  • 政府会计准则具体准则的作用
  • mysql 索引 语句
  • ubuntu20.04怎么安装
  • mac如何重装系统win10
  • mac命令行终端快捷键
  • 桌面上有desktop.ini文件
  • win8 设置
  • 在布局中使用选定的比例
  • cocoscreator lua
  • js setmap
  • 安卓炫酷壁纸
  • jQuery ajax 当async为false时解决同步操作失败的问题
  • python算法怎么用
  • 用python发邮件
  • unity接入安卓sdk
  • unity hud优化
  • 购车强制险包括哪些
  • 深圳沙井社保局在哪个位置
  • 军人残疾证家属享受待遇吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设