jquery自定義右鍵菜單、全選、不連續(xù)選擇
最近在項(xiàng)目中要實(shí)現(xiàn)一些自定義效果,例如右鍵菜單、全選、不連續(xù)選擇等等,個人認(rèn)為主要是理清楚邏輯和事件關(guān)系。要實(shí)現(xiàn)這些,也有現(xiàn)成的插件可以用,如jQuery UI的selectable。
1、右鍵菜單
當(dāng)瀏覽網(wǎng)頁時,單擊鼠標(biāo)右鍵(或ctrl+觸模板左鍵)會出現(xiàn)瀏覽器默認(rèn)的右鍵菜單項(xiàng),就像這樣子的:
但是當(dāng)要對某個元素自定義右鍵,像這樣子的:
就必須得先禁用瀏覽器默認(rèn)的菜單,需要監(jiān)聽contextmenu事件,關(guān)鍵代碼如下:
$(function(){ $('#box').on('contextmenu',function(event){ event.preventDefault(); $(this).trigger('click'); $('#menulist').css({ top: event.pageY, left: event.pageX }); }); $('#box').click(function(){ $('#menulist').css('display','block'); }); })
2、全選
默認(rèn)的ctrl+A(MAC下是command+A)會選擇整個網(wǎng)頁或者某個獲得焦點(diǎn)的可編輯元素。
<div id='box'> <p class='first'>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> </div> <div id='other'> <p class='first'>這是另外一個div,這是另外一個div,</p> <p>這是另外一個div,這是另外一個div,</p> <p>這是另外一個div,這是另外一個div,</p> <p>這是另外一個div,這是另外一個div,</p> </div>
如果頁面中只有這兩個div,按下ctrl/cmd+A這兩個div都會被選中,若只想選擇div#box的內(nèi)容,簡單地方式是給該div加上contentEditable=true。另外一種方式就是鍵盤事件的監(jiān)聽。
模擬選中div#box所有子元素p并高亮:
$(function(){ $(document).keydown(function(event){ //windows下是event.ctrlKey if(event.metaKey && event.which === 65){ event.preventDefault(); $('#box>p').trigger('click'); } }); $('#box').on('click', 'p', function(){ $(this).css('color','red'); }); });
3、shift實(shí)現(xiàn)連續(xù)的選擇
shift結(jié)合鼠標(biāo)右鍵實(shí)現(xiàn)元素的連續(xù)選擇,這里對其進(jìn)行簡單模擬。
<div id='box' class="unselect"> <p class='first'>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> <p>這是個div,這是個div,</p> </div>
按住shift時,瀏覽器有默認(rèn)的連選,先禁用掉:
.unselect{ -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; -o-user-select: none; user-select: none; }
對于低版本的IE,利用selectstart事件:
$('#box')[0].onselectstart = function(e){ e.preventDefault(); return false; };
給p注冊click事件,同時要監(jiān)聽document對象的keydown和keyup事件:
$(document).keydown(function(e){ if(e.shiftKey){ shiftkey = 1; } }).keyup(function(){ shiftkey = 0; }); $('#box').on('click','p',function(){ if(shiftkey === 1){ second = $(this).index(); for(var min = Math.min(first,second); min <= Math.max(first,second); min++){ $('#box').find('p').eq(min).css('color','red'); } } else { first = $(this).index(); $(this).css('color','red').siblings().css('color','black'); } })
4、不連續(xù)選擇
不連續(xù)選擇需要監(jiān)聽ctrl鍵(mac下command鍵),同時給元素注冊click事件。
$(document).keydown(function(e){ if(e.metaKey){ //win是e.ctrlKey ctrlkey = 2; } }).keyup(function(){ ctrlkey = 0; }); $('#box').on('click','p',function(){ if(ctrlkey === 2){ $(this).css('color','red'); } else { $(this).css('color','red').siblings().css('color','black'); } })
以上就是本文的全部內(nèi)容,希望對大家學(xué)習(xí)jquery程序設(shè)計有所幫助。
- jQuery對checkbox 復(fù)選框的全選全不選反選的操作
- 利用jQuery實(shí)現(xiàn)CheckBox全選/全不選/反選的簡單代碼
- jquery 全選、全不選、反選效果的實(shí)現(xiàn)代碼【推薦】
- 基于jquery實(shí)現(xiàn)復(fù)選框全選,反選,全不選等功能
- JQuery選中checkbox方法代碼實(shí)例(全選、反選、全不選)
- 基于jQuery實(shí)現(xiàn)復(fù)選框的全選 全不選 反選功能
- jquery全選/全不選/反選另一種實(shí)現(xiàn)方法(配合原生js)
- jquery 實(shí)現(xiàn)checkbox全選,反選,全不選等功能代碼(奇數(shù))
- jquery實(shí)現(xiàn)全選、不選、反選的兩種方法
相關(guān)文章
jquery實(shí)現(xiàn)的橫向二級導(dǎo)航效果代碼
這篇文章主要介紹了jquery實(shí)現(xiàn)的橫向二級導(dǎo)航效果代碼,可實(shí)現(xiàn)鼠標(biāo)滑過導(dǎo)航出現(xiàn)下拉菜單切換的效果,非常簡潔自然,涉及jquery鼠標(biāo)hover事件及頁面元素樣式的動態(tài)改變技巧,需要的朋友可以參考下2015-08-08jquery 回調(diào)操作實(shí)例分析【回調(diào)成功與回調(diào)失敗的情況】
這篇文章主要介紹了jquery 回調(diào)操作,結(jié)合實(shí)例形式分析了jQuery回調(diào)成功與回調(diào)失敗的情況及相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-09-09JQuery實(shí)現(xiàn)點(diǎn)擊div以外的位置隱藏該div窗口
鼠標(biāo)點(diǎn)擊div外的地方讓div窗口隱藏消失,實(shí)現(xiàn)方法有很多,在本文將為大家介紹下jquery中時如何實(shí)現(xiàn)的,感興趣的朋友不要錯過了哈2013-09-09jquery中的查找parents與closest方法之間的區(qū)別
這篇文章主要是對jquery中的查找parents與closest方法之間的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12使用jquery實(shí)現(xiàn)的一個圖片延遲加載插件(含圖片延遲加載原理)
這篇文章主要介紹了使用jquery實(shí)現(xiàn)的一個圖片延遲加載插件,同時講解了圖片延遲加載的原理,還有無阻塞加載廣告的功能哦,需要的朋友可以參考下2014-06-06jQuery Easy UI中根據(jù)第一個下拉框選中的值設(shè)置第二個下拉框是否可以編輯
這篇文章主要介紹了jQuery Easy UI中根據(jù)第一個下拉框選中的值設(shè)置第二個下拉框是否可以編輯的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-11-11