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

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

  • iphone13pro可以插几张卡(iphone13pro可以用普通充电器吗)

    iphone13pro可以插几张卡(iphone13pro可以用普通充电器吗)

  • 支付宝健康码怎么删除(支付宝健康码怎么添加到桌面)

    支付宝健康码怎么删除(支付宝健康码怎么添加到桌面)

  • 微信朋友圈视频最多发多长时间(微信朋友圈视频怎样发超过30秒)

    微信朋友圈视频最多发多长时间(微信朋友圈视频怎样发超过30秒)

  • 华为nova4发烫(华为nova4发烫怎么解决)

    华为nova4发烫(华为nova4发烫怎么解决)

  • 抖音怎么设置合拍权限(抖音设置位置怎么设定)

    抖音怎么设置合拍权限(抖音设置位置怎么设定)

  • 剪映为何识别不了字幕(剪映为何识别不了导入音频字幕)

    剪映为何识别不了字幕(剪映为何识别不了导入音频字幕)

  • 华摄氏度和摄氏度有什么区别(华摄氏度摄氏度转化)

    华摄氏度和摄氏度有什么区别(华摄氏度摄氏度转化)

  • 苹果有序列号能查什么(苹果有序列号能买吗)

    苹果有序列号能查什么(苹果有序列号能买吗)

  • 固态硬盘1t是什么意思(固态硬盘1t和1tb的区别)

    固态硬盘1t是什么意思(固态硬盘1t和1tb的区别)

  • 微信不点进去收不到信息怎么办(微信不点进去收不到视频)

    微信不点进去收不到信息怎么办(微信不点进去收不到视频)

  • 华为p40照相机怎么用(华为P40照相机怎么调照相好)

    华为p40照相机怎么用(华为P40照相机怎么调照相好)

  • 手机充电口进水会出现什么情况(手机充电口进水怎么办)

    手机充电口进水会出现什么情况(手机充电口进水怎么办)

  • 华为手机白名单在哪(华为手机白名单怎么解除)

    华为手机白名单在哪(华为手机白名单怎么解除)

  • 华硕路由器地球灯红色(华硕路由器地球灯红色后灯全灭)

    华硕路由器地球灯红色(华硕路由器地球灯红色后灯全灭)

  • 苹果11pro不能用充电宝了吗(苹果11pro不能用华为充电头吗?)

    苹果11pro不能用充电宝了吗(苹果11pro不能用华为充电头吗?)

  • 华为手机出现一个小人怎么关闭(华为手机出现一个圆圈怎么关掉)

    华为手机出现一个小人怎么关闭(华为手机出现一个圆圈怎么关掉)

  • 群封了群主会封号吗(群封了还能恢复吗)

    群封了群主会封号吗(群封了还能恢复吗)

  • 怎么把白底图ps成透明图(怎么把白底图片变成透明的)

    怎么把白底图ps成透明图(怎么把白底图片变成透明的)

  • 注册拼多多店铺需要什么(手机怎么注册拼多多店铺)

    注册拼多多店铺需要什么(手机怎么注册拼多多店铺)

  • 荣耀9xpro参数(下一页p30)

    荣耀9xpro参数(下一页p30)

  • ios12怎么关闭截图分享(iphone12关闭截图)

    ios12怎么关闭截图分享(iphone12关闭截图)

  • 苹果屏幕花屏竖条(苹果出现竖屏花屏怎么办)

    苹果屏幕花屏竖条(苹果出现竖屏花屏怎么办)

  • qq面板在哪里打开(qq面板系统设置在哪里)

    qq面板在哪里打开(qq面板系统设置在哪里)

  • SQL基础语句 - 数据定义DDL操作数据库和数据表的详细介绍(sql语句的基本用法)

    SQL基础语句 - 数据定义DDL操作数据库和数据表的详细介绍(sql语句的基本用法)

  • 一般纳税人增值税税率
  • 增值税普通发票有什么用
  • 桥闸通行费怎么做账务处理
  • 开发票怎么操作
  • 会计上视同销售的八种情况是哪些
  • 留抵税额下月抵扣的分录
  • 待摊费用属于企业的费用
  • 小规模纳税人外账处理
  • 公司与公司之间借款需要交税吗
  • 分公司可以享受小规模纳税人优惠
  • 科目余额转到其他科目
  • 增值税纳税处理
  • 个人垫付费用报销申请怎么写
  • 现金比率的计算公式是指
  • 存在银行保证金计入什么会计科目
  • 税负率是税率吗
  • 税目与应纳税额的关系
  • 一般纳税人施工安装税点
  • 企业资产损失会计处理
  • 预交增值税后如何处理
  • 会计新手入门
  • 民办非企业年底额度不能低于多少
  • 备用金的会计分类
  • 金税盘减免税款怎么结转
  • Win11/Win10 21H2 正式版发布前,微软再次推送可靠性补丁更新 KB4023057
  • 收到退回多付款现金流量支付购买商品支付
  • 加利福尼亚riverside
  • 其他业务收入对应的成本
  • 车保险理赔的钱多久到账
  • 销售自行开发的房地产
  • 解决口苦最快的方法
  • h5响应式布局是什么
  • 埃托沙国家公园发展观兽旅游的优势条件
  • 动力和燃料的区别
  • php如何实现自动加载
  • 大前端技术
  • 特斯拉适用于什么车型
  • php 命名空间 通俗易懂
  • 计提社保会计分录金额怎么写
  • 汇兑损益计算方法有哪些
  • 如何查询去年企业所得税
  • 收到现金股利或债券利息时会计分录怎么做
  • 停工损失会计科目
  • SQL Server 2008+ Reporting Services (SSRS)使用USER登录问题
  • 服务器连接db2数据库命令
  • 信用减值损失会影响营业利润吗
  • 小规模纳税人无票收入申报表怎么填
  • 零售业赠送给别人怎么做
  • 所有者权益科目有哪些
  • 新旧收入准则对比区别表
  • 二手车交易增值税发票
  • sql server数据库字段类型
  • 如何查看ubuntu系统的版本
  • macbook像素能不能提高
  • centos虚拟机配置
  • avcodec.dll是什么意思
  • xp系统无法安装win7系统
  • centos8查看cpu温度
  • 如何修改centos7的workspace name
  • win7小技巧
  • win10预览版和正式版区别
  • windows xp.exe
  • linux的用户
  • win8.1隐藏文件夹
  • 博主是re_mini_scene
  • Extjs EditorGridPanel中ComboBox列的显示问题
  • exit(1)和return的区别
  • Html5+jQuery+CSS制作相册小记录
  • linux 映射 fn键
  • 深入了解是啥意思
  • shell脚本入门详解
  • lint 工具
  • python模板引擎开发
  • 简单的安卓代码
  • javascript 数组删除
  • 税务工作创新
  • 全国税收最高
  • 福州房管局网签查询
  • 吉林省国税局网站官网
  • 税款复核需要多少天
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设