引言
前段時間發(fā)了一個編輯器的插件,忙完后自己再次進(jìn)行了詳細(xì)的測試,然后心里冒出一句:“這誰寫的這么奇葩的插件?完全沒什么luan用啊!”
自己做了讓自己不滿意的事,咋整?男人不怕累,花了時間重寫(為世界上所有像我一樣勤勞的男人點(diǎn)贊)~
思維導(dǎo)圖
在小生看來,在開發(fā)每一個新功能的時候都應(yīng)該做到心中有一張思維導(dǎo)圖:功能實(shí)現(xiàn)邏輯和實(shí)現(xiàn)功能大致的方法。當(dāng)然我們不可能在還沒動手
前就考慮得面面俱到,但在正式開發(fā)之前心里對整個流程有個清晰的印象肯定會讓我們在動手時愈加流暢(喝口娃哈哈美滋滋,看圖~):
流程效果圖
觸發(fā)檢索事件字符可自定義,默認(rèn)為 $,輸入 $ 觸發(fā)檢索顯示,此時檢索值為空,所以顯示所有選項(xiàng),繼續(xù)輸入 a ,檢索值為 a,顯示匹配選項(xiàng),當(dāng)再輸入 . 時, 檢索值獲取條件發(fā)生改變(具體我們等下看代碼),
圖四中為整個流程在控制臺中的記錄。
js代碼 -- 監(jiān)聽輸入框
全局變量
考慮到里面小方法比較多,為了簡化代碼,這里我選擇模塊化一下,需要用到以下全局變量。這里特別提一下:持續(xù)事件和點(diǎn)事件的區(qū)別,持續(xù)顧名思義,持續(xù)事件就是一直觸發(fā)的事件,這里 $ 觸發(fā)檢索事件后,檢索值 selectVal
是變化的,但是我們又不需要它一直處于觸發(fā)狀態(tài),怎么辦呢?對,開關(guān),我們可以給這個事件設(shè)置一個開關(guān),條件滿足時打開開關(guān),事件持續(xù)觸發(fā),結(jié)束后關(guān)閉開關(guān),結(jié)束檢索事件,這里設(shè)置的開關(guān)是:searchStart;而點(diǎn)事件
這里就是輸入 . 時觸發(fā)的事件,它只需要在輸入 . 時獲取相關(guān)的值就行了,不需要連續(xù)觸發(fā),這里我們設(shè)置參數(shù) enterCharacter : 當(dāng)前輸入的字符
var _this = $(this); var e = event || window.event; // 鍵值兼容 var searchStart = false; // 設(shè)置檢索事件開關(guān) var checkCharacter = false; // 輸入字符檢索開關(guān) var oldCurrentPos = ''; // 檢索值開始的位置 var currentPos = ''; // 檢索值結(jié)束的位置 var selectVal = ''; // 檢索值 var pos = ''; // 設(shè)置光標(biāo)位置 var enterCharacter = ''; // 當(dāng)前輸入的字符 var dotVal; // 輸入 . 時從0到當(dāng)前光標(biāo)位置文本 var dotDollerPos; // 獲取往后查找離 . 最近的 $ 的下標(biāo),引文輸入 . 時的檢索值即dotSelectVal不包含 $ 本身,所以需要加1 var dotSelectVal; // 輸入 . 時的檢索值
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
新聞名稱:js公式編輯器-自定義匹配規(guī)則-帶提示下拉框-動態(tài)獲取光標(biāo)像素坐標(biāo)-創(chuàng)新互聯(lián)
文章鏈接:http://chinadenli.net/article46/ihihg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、品牌網(wǎng)站建設(shè)、企業(yè)建站、建站公司、網(wǎng)頁設(shè)計公司、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容