日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue實(shí)現(xiàn)一個(gè)獲取按鍵展示快捷鍵效果的Input組件

瀏覽:19日期:2022-10-11 09:42:15

遇到一個(gè)需求,頁(yè)面內(nèi)要自定義快捷鍵,這就需要可以有地方設(shè)置和展示快捷鍵,找了一圈Element UI發(fā)現(xiàn)沒有能稍微改改就能用的組件,所以自己動(dòng)手寫了一個(gè)。這個(gè)只有快捷鍵展示功能,快捷鍵實(shí)際綁定生效的話是依賴傳回的快捷鍵數(shù)據(jù),由另外的組件處理的。目前只測(cè)試了Chrome的環(huán)境。

效果如下:

vue實(shí)現(xiàn)一個(gè)獲取按鍵展示快捷鍵效果的Input組件

關(guān)鍵點(diǎn)

雖然看起來(lái)像是一個(gè)Input但在組件內(nèi)實(shí)際上是展示一個(gè)標(biāo)簽效果,還需要有刪除按鈕。這就得在輸入框內(nèi)放下html代碼,瀏覽器的Input組件顯然不適合,這就只能自己仿一個(gè)類Input組件效果了。

focus、blur、選中高亮效果

非Input這類組件是沒有focus、blur、選中高亮效果這些效果的,還好瀏覽器有預(yù)留實(shí)現(xiàn)方式,網(wǎng)上也早已有網(wǎng)友提供方案,在div里加上tabindex='0'屬性,就能讓div獲得這些效果。

tabindex屬性規(guī)定了Tab按鍵的順序,寫0的話是會(huì)按組件默認(rèn)順序被選中的,如果寫-1則始終無(wú)法被選中。因?yàn)楸旧硎欠翴nput組件形式,能被Tab獲取也剛好很合理。

然后加上CSS的獲取焦點(diǎn)的邊框效果、鼠標(biāo)移動(dòng)到此顯示文本類型指針

.shortcut-key-input { cursor: text; transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);}.shortcut-key-input:focus { border-color: #188cff; box-shadow: 0 0 4px rgba(24, 140, 255, 0.38);}文本提示

當(dāng)沒有內(nèi)容時(shí)需要跟Input一樣,可以默認(rèn)顯示文本提示。這也是放一個(gè)div在里面,用Vue控制,如果輸出的標(biāo)簽變量有數(shù)據(jù)時(shí),就不讓此元素顯示。

光標(biāo)閃動(dòng)效果

這個(gè)比較好處理,在類Input里面放一個(gè)偽元素,當(dāng)獲取焦點(diǎn)的時(shí)候添加此偽元素,然后再給此元素一個(gè)CSS3的動(dòng)畫,就有光標(biāo)閃動(dòng)的效果了。

@keyframes Blink { 0% { opacity: 0; } 100% { opacity: 1; }}.shortcut-key-input.cursor::after { content: '|'; animation: Blink 1.2s ease 0s infinite; font-size: 18px; position: absolute; top: 1px; left: 8px;}按鍵捕獲

按鍵捕獲主要靠keydown事件,其中傳回的event里會(huì)標(biāo)記是否按下alt、ctrl(control)等信息,所以做組合按鍵依賴此信息就可以實(shí)現(xiàn)。因?yàn)槊看伟存I都會(huì)觸發(fā)事件,所以要屏蔽掉功能鍵的事件。代碼只實(shí)現(xiàn)了一個(gè)非功能鍵的組合,需要多功能鍵可以另外建立變量判斷連續(xù)按鍵的情況然后處理。

handleKeydown(e) { const { altKey, ctrlKey, shiftKey, key, code } = e; if (!CODE_CONTROL.includes(key)) { if (!this.keyRange.includes(code)) return; let controlKey = ''; [ { key: altKey, text: 'Alt' }, { key: ctrlKey, text: 'Ctrl' }, { key: shiftKey, text: 'Shift' } ].forEach(curKey => { if (curKey.key) { if (controlKey) controlKey += '+'; controlKey += curKey.text; } }); if (key) { if (controlKey) controlKey += '+'; controlKey += key.toUpperCase(); } this.addHotkey({ text: controlKey, controlKey: { altKey, ctrlKey, shiftKey, key, code } }); } e.preventDefault(); },

CODE_CONTROL是另外預(yù)設(shè)的按鍵code碼集合,方便處理。本來(lái)用的是keyCode的,但keyCode已經(jīng)被廢棄了,推薦的是code。addHotkey就是添加到相應(yīng)變量的函數(shù),其中主要出判斷一下是否有重復(fù)的快捷鍵。然后預(yù)留了一個(gè)外部驗(yàn)證的接口,為了多快捷鍵的時(shí)候可以判斷是否有重復(fù)。還有一個(gè)max接口,可以限制每個(gè)組件的快捷鍵個(gè)數(shù)。

addHotkey(data) { if (this.list.length && this.list.some(item => data.text === item.text)) return; if (this.list.length && this.list.length.toString() === this.max.toString()) return; if (!this.verify(data)) return; this.list.push(data); }在線預(yù)覽

https://codesandbox.io/s/vue-hotkeyinput-90m2k

以上就是vue實(shí)現(xiàn)一個(gè)獲取按鍵展示快捷鍵效果的Input組件的詳細(xì)內(nèi)容,更多關(guān)于vue 展示快捷鍵的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
西西人体一区二区| 噜噜噜久久亚洲精品国产品小说| 99视频精品视频高清免费| 国产伦一区二区三区| 免费在线成人网| japanese国产精品| 视频福利一区| 国产精品男女| 国产精品一区毛片| 日本va欧美va精品发布| 在线一区二区三区视频| 国内精品99| 成人看片网站| 国产精品国产一区| 风间由美中文字幕在线看视频国产欧美| 国产情侣一区在线| 久久国内精品自在自线400部| 日韩av中文字幕一区二区 | 国产精品一区二区三区四区在线观看| 久久久久免费av| 99精品视频精品精品视频| 午夜精品成人av| 久久国产中文字幕| 国产专区一区| 精品一区在线| 中文久久精品| 亚欧洲精品视频在线观看| 伊人久久亚洲美女图片| 久久婷婷亚洲| 激情婷婷欧美| 日韩专区欧美专区| 国产精品最新| 日韩中文影院| 蜜臀av国产精品久久久久| 欧美日韩国产亚洲一区| 在线观看亚洲精品福利片| 日韩高清一级| 九九九精品视频| 久久午夜影院| 久久一区二区三区电影| 9久re热视频在线精品| 亚洲精品激情| 国产一区二区亚洲| 欧美日韩在线二区| 视频一区二区不卡| 国产精品午夜av| 国产自产自拍视频在线观看| 久久精品国产www456c0m| 亚洲免费网址| 欧美日韩精品一区二区三区视频 | 精品网站999| 久久三级视频| 亚洲免费专区| 鲁鲁在线中文| 中文欧美日韩| 日本麻豆一区二区三区视频| 精品免费视频| 亚洲精品小说| 国产精品超碰| 国产精品社区| 成人精品视频| 日韩精品一区二区三区中文字幕| 久久精品毛片| 男女男精品网站| 成人午夜网址| 免费看欧美美女黄的网站| 国产精品视区| 精品不卡一区| 视频一区欧美日韩| 国产精品成人a在线观看| 亚洲二区免费| 精品国产乱码久久久| 免费成人在线观看| 欧美www视频在线观看| 综合国产视频| 91精品久久久久久久久久不卡| 日韩三级久久| 午夜精品免费| 久久一区国产| 亚洲精品日韩久久| 极品日韩av| av最新在线| 91精品99| 91亚洲成人| 欧美在线看片| 伊人精品在线| xxxxx性欧美特大| 国产亚洲高清一区| 激情婷婷综合| 黄色在线观看www| 国产丝袜一区| 日韩一区二区三区高清在线观看 | 亚洲一区免费| 97人人精品| 国产精品99久久免费| 蜜桃视频在线观看一区二区| 国产成人精品福利| 久久国产视频网| 鲁大师成人一区二区三区| se01亚洲视频| 日本蜜桃在线观看视频| 麻豆精品久久久| 国产精品久久久久77777丨| 日韩欧美在线精品| 亚洲精品伦理| 蜜臀av亚洲一区中文字幕| 黄色在线一区| 欧美日韩国产免费观看视频| 亚洲精品成人图区| 国语对白精品一区二区| 麻豆国产欧美日韩综合精品二区| 69堂精品视频在线播放| 亚洲欧美一级| 99国产精品| 亚洲黄色在线| 国产精品婷婷| 一二三区精品| 欧美成人综合| 欧美日韩国产欧| 亚洲一区二区三区免费在线观看| 国精品一区二区三区| 亚洲va在线| 香蕉国产精品| 日韩制服丝袜av| 亚洲综合国产| 欧美精品一线| 免费观看在线综合色| 蜜桃久久av一区| 欧美中文高清| 国产精品一区高清| 国产毛片久久久| 美女视频网站久久| 国产精品成人a在线观看| 色爱综合网欧美| 久久91导航| 91久久久久| 欧美在线黄色| 中文字幕人成乱码在线观看 | 免费观看不卡av| 日韩精品午夜视频| 美女一区网站| 日本a级不卡| 欧美二三四区| 日韩av中文字幕一区二区三区| 亚洲精品一级二级| 欧美久久久网站| 日韩视频精品在线观看| 九九久久国产| 日韩中文字幕在线一区| 欧美日韩精品免费观看视欧美高清免费大片 | 麻豆中文一区二区| 韩国精品主播一区二区在线观看 | 欧美私人啪啪vps| 蜜桃成人av| 精品免费av一区二区三区| 亚洲综合三区| 中文字幕在线视频久| 日韩午夜视频在线| 女人天堂亚洲aⅴ在线观看| 久久影院一区二区三区| 国产视频一区三区| 国产一区福利| 国产亚洲精品美女久久| 免费国产自线拍一欧美视频| 日本在线啊啊| 国产精东传媒成人av电影| 免费日韩精品中文字幕视频在线| 国产一区二区亚洲| 日本久久二区| 免费视频久久| 国产一区观看| 精品日韩视频| 国产精品久久观看| 久久99蜜桃| 91福利精品在线观看| 国产农村妇女精品一区二区| 亚洲精品国产嫩草在线观看| 麻豆一区在线| 国产精品一区二区免费福利视频 | 一区二区电影在线观看| 国产主播一区| 久久婷婷久久| 91看片一区| 国产一区二区精品久| 国产乱码精品一区二区亚洲| 亚洲精品美女| 午夜亚洲福利| 亚洲无线观看| 免费av一区二区三区四区| 日韩大片在线观看| 不卡专区在线| sm捆绑调教国产免费网站在线观看| 国产精久久久| 鲁大师精品99久久久| 人人爱人人干婷婷丁香亚洲| 日本不卡高清| 国产欧美丝祙| 欧美国产不卡| 精品一区二区三区中文字幕视频| 国产剧情在线观看一区|