# checkbox取消選中不好使
直接說結論:u-checkbox-group的v-model和checkbox的checked屬性是互相沖突的,兩個只能選擇一個,如果都選上了就會出現這個bug,復現問題的代碼如下:
```vue
<template>
<u-checkbox-group
v-model="checkboxValue2" // 關鍵部分,給checkbox-group綁定v-model
placement="column"
@change="checkboxChange"
shape="square"
>
<u-checkbox
:customStyle="{marginBottom: '8px'}"
v-for="(item, index) in checkboxList2"
:key="index"
:label="item.name"
:name="item.name"
:checked="true" // 關鍵部分,給子組件指定checked屬性
>
</u-checkbox>
</u-checkbox-group>
</template>
<script>
export default {
data() {
return {
checkboxList2: [{
name: '西游記',
disabled: false
},
{
name: '紅樓夢',
disabled: false
},
{
name: '三國演義',
disabled: false
},
{
name: '水滸傳',
disabled: false
}
],
// u-checkbox-group的v-model綁定的值如果設置為某個checkbox的name,就會被默認選中
checkboxValue2: ['西游記', '紅樓夢', '三國演義', '水滸傳'],
}
}
}
</script>
```
此時就會發現怎么取消也取消不了。
## 問題原理
在checkbox-group里的value變化的時候會重新調用一遍子組件的init方法,init方法會檢查checked來確定自己的選中狀態,所以其實是取消成功了的,但是它又以很快的速度給你勾選上了,人眼看不出來就會認為是取消不動。
## 解決方案
兩個屬性不要一起設置就好了。
> 本文作者: 不愛喝橙子汁
- 自述
- 學會提問
- 起步
- 安裝
- 版本升級
- 1.x 升級 2.x 常見問題
- 命令行模式下node-sass安裝錯誤
- 查看版本
- uView UI 1.x 相關問題
- 安裝
- Popup 彈窗
- tabs 標簽
- Waterfall 瀑布流
- Table 表格
- Dropdown 下拉菜單
- uview-ui組件篇
- u-upload監聽beforeRead事件無效
- 組件怎么關不了
- 導航欄不默認返回好麻煩
- ref怎么獲取不到
- z-index拉滿都覆蓋不了map
- u-text對手機號脫敏
- u-input的placeholder去不掉
- 服務端返回數據,form表單驗證錯誤
- checkbox增加選中面積
- uview-ui組件篇/checkbox無法取消選中
- 小程序輸入框的placeholder會穿透到彈出層
- JavaScript篇
- 判斷數據類型
- 數組操作
- 節流與防抖函數
- this怎么就不對
- 計算地圖上兩點間的距離
- CSS篇
- 我要超出顯示省略號
- uniapp中小程序樣式穿透問題
- 關鍵幀與動畫
- CSS動畫屬性總結
- 過渡與動畫
- 正則表達式篇
- 身份證號
- 手機號
- 是否合法的http/https域名
- 數據處理篇
- 對數組分組
- 深拷貝對象
- 提取數組屬性
- 提取對象屬性
- 常見問題
- 如何給由組件觸發的事件中傳入自定義的參數
- 分類的雙列聯動
- 三級聯動的實現
- 小程序預覽提示包過大
- 框架安裝失敗
- 表格、瀑布流、下拉列表 組件為什么沒有了
- tabBar組件怎么用
- 時間、日歷、選擇器相關問題
- 字體圖標不顯示
- class 或 /deep/ 不生效