單選表格在網(wǎng)頁(yè)應(yīng)用中很常見,它能讓用戶方便地從多個(gè)選項(xiàng)中選擇一個(gè)。Vue是一款優(yōu)秀的前端框架,能夠讓我們快速地實(shí)現(xiàn)單選表格的功能。接下來我們將介紹選用Vue實(shí)現(xiàn)單選表格的基本思路和具體實(shí)現(xiàn)方法。
首先,我們需要明確單選表格的基本功能。它需要有多行數(shù)據(jù),每行數(shù)據(jù)中包含一個(gè)單選框和多個(gè)文本框。當(dāng)用戶勾選了某一行的單選框時(shí),這一行的數(shù)據(jù)將被選中;同時(shí),之前選中的行的單選框?qū)⒆詣?dòng)取消勾選。因此,實(shí)現(xiàn)單選表格的核心是實(shí)現(xiàn)行間的單選框互斥。
<table> <thead> <tr> <th>ID</th> <th>Name</th> <th>Score</th> <th>Select</th> </tr> </thead> <tbody> <tr v-for="item in list" :key="item.id" :class="{selected: item.selected}" @click="selectRow(item)"> <td>{{ item.id }}</td> <td>{{ item.name }}</td> <td>{{ item.score }}</td> <td><input type="radio" :name="'select-'+item.id" :checked="item.selected"></td> </tr> </tbody> </table>
以上是一個(gè)基本的HTML代碼,用于展示包含單選框的表格。其中,我們采用了Vue的v-for指令遍歷數(shù)組list中的數(shù)據(jù),生成多行表格。:key指令用于為每行生成一個(gè)唯一標(biāo)識(shí)符,確保Vue能夠準(zhǔn)確地渲染出這一行的數(shù)據(jù)。:class指令用于動(dòng)態(tài)綁定CSS類,根據(jù)item.selected的值動(dòng)態(tài)確定是否為該行添加selected類。@click指令用于對(duì)每一行的點(diǎn)擊事件進(jìn)行監(jiān)聽,當(dāng)用戶點(diǎn)擊這一行時(shí),selectRow方法將會(huì)被調(diào)用。
methods: { selectRow(item) { this.list.forEach(i =>{ i.selected = (i === item); }); } }
以上是一個(gè)基本的Vue代碼,用于實(shí)現(xiàn)單選表格的核心功能:行間單選框互斥。當(dāng)用戶點(diǎn)擊某一行時(shí),selectRow方法將會(huì)被調(diào)用。該方法將會(huì)遍歷數(shù)組list中的所有數(shù)據(jù),將當(dāng)前行置為選中狀態(tài),其他行置為非選中狀態(tài)。在Vue的數(shù)據(jù)綁定機(jī)制下,當(dāng)其中一行被選中時(shí),其他行的選中狀態(tài)將自動(dòng)取消。
除了以上的基本實(shí)現(xiàn)方法,我們還可以對(duì)單選表格進(jìn)行進(jìn)一步的優(yōu)化。例如,我們可以為每行綁定一個(gè)方法,讓用戶點(diǎn)擊行內(nèi)的任意元素時(shí)都可以觸發(fā)單選框的勾選。我們還可以在選中某行的同時(shí)觸發(fā)相應(yīng)的數(shù)據(jù)操作,例如展示該行的詳細(xì)信息或者執(zhí)行該行的刪除操作。在實(shí)際應(yīng)用中,單選表格的功能是多種多樣的,我們需要根據(jù)具體需求進(jìn)行靈活地調(diào)整和擴(kuò)展。