您好,登錄后才能下訂單哦!
如何在vue中使用checkbox?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
原生checkbox搭配jquery取值的用法
<input type="checkbox" name="hobby" value="游泳">游泳 <input type="checkbox" name="hobby" value="健身">健身 <input type="checkbox" name="hobby" value="旅游">旅游 $(".section1 input[type=checkbox][name=hobby]").change(function(){ var obj = document.getElementsByName("hobby"); var check_val = []; for(k in obj){ if(obj[k].checked){ check_val.push(obj[k].value); } } $(".section1 .res").text(check_val); });
checkbox禁用
<input type="checkbox" name="hobby" value="游泳" checked disabled="true">游泳
在vue中checkbox用法
在vue中,v-model其實是checked語法糖,通過v-model來判斷當前checkbox是否被選中, 它綁定一個數組,選中項的值會自動添加到數組中
<div>請選擇你的愛好(vue)</div> <input type="checkbox" v-model="hobby2" value="游泳">游泳 <input type="checkbox" v-model="hobby2" value="健身">健身 <input type="checkbox" v-model="hobby2" value="旅游">旅游 <div>你已選中:{{hobby2}}</div> var vm = new Vue({ el: '#app', data:{ msg:'hello', hobby2:[] }, created(){ console.log('created') }, method:{ login:function(){ alert(1) } } })
vue中checkbox禁用
假如我們要求選項至少選擇一個值,我們來通過disabled來禁止用戶取消點擊選項
這里主要是通過設置hobby2的值來控制checkbox選項的選中或取消
1.首先先將hobby2數組設置一個默認值hobby2:['游泳']
2.添加input點擊事件
<input type="checkbox" v-model="hobby2" value="游泳" @click="handleClick">游泳 handleClick:function(ev){ var that = this; setTimeout(function(){ console.log('this.hobby2',ev.target.checked,that.hobby2.length,that.hobby2) if(!ev.target.checked){ if(that.hobby2.length==1){ that.lastcheckval = that.hobby2[0]; } if(that.hobby2.length==0){ that.hobby2.push(that.lastcheckval) } } },1) }
1.通過獲取點擊事件 ev.target.checked的值判斷當前點擊狀態是取消還是選中
如是取消狀態,則判斷當前hobby2長度為0時通過push將lastcheckval最后一個值添加進去,這樣就無法取消最后一個選項
lastcheckval的值需要在hobby2數組長度為1時將選項值保存起來
setTimeout異步
這里的如果不使用setTimeout異步,當點擊選中或者取消選項時,數組hobby2中的值還是上一個選項結果,為了保證一致添加setTimeout解決該問題
剛才我們通過控制v-model中hobby2的值來禁止用戶取消最后一個選項,那如果我們要實現這樣一個功能又如何做呢
1.用戶最多只能選擇2個選項 (交互效果:當當前選項長度為2時,用戶去選擇新的選項時,將第一個選項取消,依次類推)
在checked為false時添加如下代碼,判斷hobby2長度大于2時,將第一個元素刪除
if(that.hobby2.length>2){ that.hobby2.splice(0,1); }
自定義checkbox樣式
默認的checkbox樣式十分丑陋,不同的瀏覽器展示效果也不一樣,如果是設計出圖的話,我們就需要自定義樣式,
結合vue checkbox選項禁用來自定義checkbox樣式
原理
1.通過label標簽將input包裹住通過label for綁定input id,當點擊label時實際就是點擊的input
將input設置opacity: 0;不可見
2.通過給div來設置checkbox的默認樣式及選中狀態樣式
.section3 .checkboxlist{} .checkboxlist label{ margin-left: 10px; } .checkboxlist .checkbox{ display: inline-block; width: 14px; height: 14px; border: 1px solid #eee; margin-right: -20px; } .checkboxlist .checkbox.checked{ background: blue; } .checkboxlist input{ opacity: 0; }
checkbox選項選中狀態checked類動態添加 ,判斷hobby3中是否存在當前選項值來覺得是否綁定checked類
:class="hobby3.indexOf('游泳')!=-1?'checked':''" <label for="游泳"> <div class="checkbox" :class="hobby3.indexOf('游泳')!=-1?'checked':''"></div> <input type="checkbox" id="游泳" v-model="hobby3" value="游泳" @click="handleClick">游泳 </label> <label for="健身"> <div class="checkbox" :class="hobby3.indexOf('健身')!=-1?'checked':''"></div> <input type="checkbox" id="健身" v-model="hobby3" value="健身" @click="handleClick">健身 </label> <label for="旅游"> <div class="checkbox" :class="hobby3.indexOf('旅游')!=-1?'checked':''"></div> <input type="checkbox" id="旅游" v-model="hobby3" value="旅游" @click="handleClick">旅游 </label> <label for="爬山"> <div class="checkbox" :class="hobby3.indexOf('爬山')!=-1?'checked':''"></div> <input type="checkbox" id="爬山" v-model="hobby3" value="爬山" @click="handleClick">爬山 </label>
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。