国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jquery自定義右鍵菜單、全選、不連續(xù)選擇

2019-11-20 10:28:09
字體:
供稿:網(wǎng)友

最近在項(xiàng)目中要實(shí)現(xiàn)一些自定義效果,例如右鍵菜單、全選、不連續(xù)選擇等等,個(gè)人認(rèn)為主要是理清楚邏輯和事件關(guān)系。要實(shí)現(xiàn)這些,也有現(xiàn)成的插件可以用,如jQuery UI的selectable。

1、右鍵菜單
當(dāng)瀏覽網(wǎng)頁時(shí),單擊鼠標(biāo)右鍵(或ctrl+觸模板左鍵)會(huì)出現(xiàn)瀏覽器默認(rèn)的右鍵菜單項(xiàng),就像這樣子的:

但是當(dāng)要對(duì)某個(gè)元素自定義右鍵,像這樣子的:

就必須得先禁用瀏覽器默認(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)會(huì)選擇整個(gè)網(wǎng)頁或者某個(gè)獲得焦點(diǎn)的可編輯元素。

<div id='box'> <p class='first'>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p></div><div id='other'> <p class='first'>這是另外一個(gè)div,這是另外一個(gè)div,</p> <p>這是另外一個(gè)div,這是另外一個(gè)div,</p> <p>這是另外一個(gè)div,這是另外一個(gè)div,</p> <p>這是另外一個(gè)div,這是另外一個(gè)div,</p></div>

如果頁面中只有這兩個(gè)div,按下ctrl/cmd+A這兩個(gè)div都會(huì)被選中,若只想選擇div#box的內(nèi)容,簡(jiǎn)單地方式是給該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ù)選擇,這里對(duì)其進(jìn)行簡(jiǎn)單模擬。

<div id='box' class="unselect"> <p class='first'>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p> <p>這是個(gè)div,這是個(gè)div,</p></div>

按住shift時(shí),瀏覽器有默認(rèn)的連選,先禁用掉:

.unselect{ -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; -o-user-select: none; user-select: none;}

對(duì)于低版本的IE,利用selectstart事件:

$('#box')[0].onselectstart = function(e){  e.preventDefault();  return false; };

給p注冊(cè)click事件,同時(shí)要監(jiān)聽document對(duì)象的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鍵),同時(shí)給元素注冊(cè)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');  } })

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)jquery程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 绿春县| 新巴尔虎右旗| 富民县| 三门峡市| 宣恩县| 弥勒县| 皋兰县| 玉屏| 外汇| 阿克苏市| 清水河县| 两当县| 资阳市| 桦南县| 鲁甸县| 九江市| 扬中市| 武功县| 手游| 沙坪坝区| 临西县| 基隆市| 台北市| 马龙县| 平顶山市| 晋江市| 淳安县| 阿鲁科尔沁旗| 莎车县| 马关县| 彰化县| 永嘉县| 喜德县| 霍山县| 夹江县| 成安县| 吕梁市| 公主岭市| 襄垣县| 双城市| 都兰县|