uni-table 行无法添加点击事件的解决办法

本文介绍了如何在Vue项目中利用SFSaver,JSZip和SQrcodeJS2库实现批量生成企业信息二维码图片,并将其打包成压缩包下载。针对大数据量的情况,文中还给出了优化建议。

uni-table 行无法添加点击事件的解决办法

使用 @click.native 绑定事件,经测试在真机及小程序都管用。

<template>
	<view>
		<!-- 表头数据 -->
		<uni-tr>
			<uni-th>物品类型</uni-th>
			<uni-th>数量</uni-th>
			<uni-th>单价</uni-th>
			<uni-th>金额</uni-th>
		</uni-tr>
		
		<!-- 每行数据 -->
		<uni-tr v-for="(item,index) in commodityList" :key="index" @click.native="trClick(index)">
			<uni-td>{{item.name}}</uni-td>
			<uni-td>{{item.count}}</uni-td>
			<uni-td>{{item.price}}</uni-td>
			<uni-td>{{item.totalPrice}}</uni-td>
		</uni-tr>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				commodityList: [ //商品信息
					{
						name: "商品A",
						count: 100,
						price: 10.00,
						totalPrice: 1000.00,
					},
					{
						name: "商品B",
						count: 32,
						price: 11.00,
						totalPrice: 352.00,
					}, {
						name: "商品C",
						count: 10,
						price: 1.61,
						totalPrice: 16.10,
					},
				]
			}
		},
		methods: {
			trClick(row) {
				console.log(`"点击了${row}行"`)
			},
		}
	}
</script>
### uni-app中uni-table组件的点击事件使用方法 在 `uni-app` 的开发过程中,`uni-table` 是一个非常实用的表格展示工具。为了增强用户体验,通常需要为表格中的每一添加点击事件以便执特定的操作。以下是基于已有引用内容和专业知识总结的两种实现方式。 #### 方法一:通过自定义插槽绑定点击事件 此方法无需修改原生 `tr` 组件结构,而是利用 `uni-table` 提供的自定义单元格功能来绑定点击事件[^3]。 ```html <template> <view> <!-- 表格 --> <uni-table border stripe emptyText="暂无数据"> <uni-tr> <uni-th>列名1</uni-th> <uni-th>列名2</uni-th> </uni-tr> <block v-for="(item, index) in tableData" :key="index"> <uni-tr @click="rowClick(item)"> <uni-td>{{ item.col1 }}</uni-td> <uni-td>{{ item.col2 }}</uni-td> </uni-tr> </block> </uni-table> <!-- 分页 --> <view class="pagination-wrap"> <uni-pagination show-icon :page-size="pageSize" :current="currentPage" :total="total" @change="onPageChange"/> </view> </view> </template> <script> export default { data() { return { pageSize: 10, currentPage: 1, total: 50, tableData: [ { col1: '数据1', col2: '数据A' }, { col1: '数据2', col2: '数据B' } ] }; }, methods: { rowClick(rowItem) { console.log('点击了某一:', rowItem); // 可在此处触发导航或其他逻辑操作 }, onPageChange(e) { this.currentPage = e.current; console.log('分页切换到第几页:', e.current); // 加载对应的数据 } } }; </script> <style scoped> .pagination-wrap { margin-top: 20px; } </style> ``` 上述代码展示了如何通过 `@click` 监听器为每绑定点击事件传递当前的数据作为参数。 --- #### 方法二:重写 `tr` 组件扩展其为 如果希望更灵活地控制为,则可以考虑重新封装 `tr` 组件,在内部实现更多定制化逻辑。 以下是一个简单的例子: ```javascript // 自定义 tr.js 文件 import Vue from 'vue'; const CustomTr = Vue.extend({ name: 'CustomTr', props: ['rowData'], template: ` <uni-tr @click.native="handleRowClick"> <slot></slot> </uni-tr> `, methods: { handleRowClick() { this.$emit('custom-row-click', this.rowData); // 将数据回传给父级 } } }); export default CustomTr; ``` 接着可以在模板中引入该组件替代默认的 `<uni-tr>` 标签: ```html <template> <view> <uni-table border stripe emptyText="暂无数据"> <custom-tr v-for="(item, index) in tableData" :key="index" :rowData="item" @custom-row-click="rowClicked"> <uni-td>{{ item.col1 }}</uni-td> <uni-td>{{ item.col2 }}</uni-td> </custom-tr> </uni-table> </view> </template> <script> import CustomTr from './path/to/CustomTr'; export default { components: { CustomTr }, data() { return { tableData: [{ col1: '测试1', col2: '值A' }, { col1: '测试2', col2: '值B' }] }; }, methods: { rowClicked(data) { console.log('子组件触发的点击事件:', data); } } }; </script> ``` 这种方法允许开发者完全掌控级别的交互细节。 --- ### 总结 以上分别介绍了直接绑定点击事件与重构 `tr` 组件这两种不同的解决方案。前者简单易用适合大多数场景;后者则提供了更高的自由度,适用于复杂业务需求下的项目开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值