日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

新建指令避开 Avalon 的 ms-duplex 的问题

發布時間:2025/4/16 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 新建指令避开 Avalon 的 ms-duplex 的问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前端框架 Avalon 有一個問題,即 在使用 ms-duplex 后,此 input 在 Windows 8.1 的 IE11 下無法正常使用輸入法輸入中文,這個問題在 Avalon 1.5.X 中一直存在且被復現。

既然無法直接修復,那么就使用 avalon.directive 自定義一個新的指令來簡單地處理雙向數據綁定。起名為 ms-model,名字來源于 Angular.

實現如下:

avalon.directive("model", {init: function (binding) {// binding 為指令初始化時注入對象.init(binding)();},// 此方法類似 Get / Set, 在控制器使用 $watch 監視 (binding.expr, 即 ms-model="expr") 時觸發, 可在此做一些雜七雜八的事情.update: function (newVal, oldVal) {// this 為 init 中的 bingding 對象.this.element.value = newVal;} });// Definition: ms-model. function init (binding) {var thisElement = binding.element; // 指令所在的節點.var directiveValue = binding.expr; // 指令綁定的屬性.var imeIgnored = false; // 輸入法忽略控制標識.// 初始化賦值. 必須推入任務隊列才生效.setTimeout(function () {thisElement.value = binding.oldValue !== undefined ? binding.oldValue : ""; // 未賦值進行清空, 防止 IE / Edge 緩存.}, 1);// Definition: Input 事件.var inputEvent = function (event) {if (imeIgnored) { return; }// vmodels 是指令所在的控制器的數組, 看起來是按照 [孫, 子, 父] 的冒泡順序排序, 但未肯定.// ms-duplex 只處理了指令所在的最近的控制器的數值, 在此也只處理 vmodels[0].eval('binding.vmodels[0].' + directiveValue + ' = thisElement.value;'); // 使用 eval 解決多層嵌套問題.};return function () {// 在使用輸入法的時候不進行數據同步.// 進入輸入法狀態時鎖定控制標識.avalon.bind(thisElement, "compositionstart", function () {imeIgnored = true;});// 輸入法恢復時釋放控制標識.avalon.bind(thisElement, "compositionend", function () {imeIgnored = false;inputEvent(); // Fixing for Edge, Edge 的日語輸入法的 input 事件在 compositionend 之前執行, 而其他瀏覽器包括 IE11 全是 compositionend 之后, 需要手動觸發一次.});// 設置 Input 事件.avalon.bind(thisElement, "input", inputEvent, false);// 修復 IE 問題.if (window.ScriptEngine && window.ScriptEngine()) {// 修復 IE9 的 Backspace / Delete 剪切不觸發 Input 事件的問題.if (navigator.appVersion.indexOf("MSIE 9.0") > -1) {avalon.bind(thisElement, "cut", function () {setTimeout(inputEvent, 1); // 必須推入任務隊列中執行才生效.});}// IE 額外注冊 KeyUp 進行數據綁定來避免輸入法無效的問題.avalon.bind(thisElement, "keyup", function (event) {event = event || window.event;if (event.keyCode === 17 || event.keyCode === 18 || event.ctrlKey || event.shiftKey || event.altKey) { return; }inputEvent();});}} }

總結

以上是生活随笔為你收集整理的新建指令避开 Avalon 的 ms-duplex 的问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 少女情窦初开的第4集在线观看 | 亚洲精品一区二区在线 | 亚洲av人人澡人人爽人人夜夜 | 伊人春色在线视频 | 小毛片网站 | 337p粉嫩大胆噜噜噜亚瑟影院 | 国产传媒在线播放 | 成人福利午夜 | 五月婷婷狠狠爱 | 天天干人人干 | 久久久激情网 | 男生和女生一起搞鸡 | 一区二区三区免费播放 | 国产人妻人伦精品1国产盗摄 | 精品无码人妻一区二区免费蜜桃 | 啪网址 | 香港三级日本三级韩国三级 | 日韩中文字幕在线免费观看 | 狠狠综合久久av一区二区 | 国产又粗又爽视频 | 国产精品久久久久免费 | 午夜久久久久久噜噜噜噜 | 亚洲第一页夜 | 亚洲福利视频导航 | 日韩网站视频 | 视频国产一区 | 亚洲欧洲免费视频 | 国产97自拍 | 精品久久亚洲 | 国产一区二区三区免费 | 精彩久久 | 91免费黄 | 精人妻一区二区三区 | 国产一级一级 | 91美女在线观看 | 日本二区视频 | 国模少妇一区二区 | 99热只有这里有精品 | 国产成人av一区 | 色视频综合 | 97精品人人a片免费看 | 午夜精品福利一区二区蜜股av | 亚洲AV无码国产精品午夜字幕 | 年代下乡啪啪h文 | yy6080久久| 亚洲欧美在线观看 | 午夜精品久久久久久久久久久久 | 欧美三级网站在线观看 | 亚洲图片视频小说 | 91超碰人人| 999国内精品永久免费视频 | 亚洲欧美在线成人 | 欧美日韩激情一区 | 波多野结衣在线免费观看视频 | 超碰人人艹| 久久亚洲av永久无码精品 | 欧美激情视频一区二区三区不卡 | 中文在线一区二区三区 | 一级影片在线观看 | 一二三区av | 懂色一区二区三区免费观看 | 夫妻啪啪呻吟x一88av | 国产免费一区二区三区三州老师 | 久久精品国产精品亚洲毛片 | 337p日本欧洲亚洲鲁鲁 | 国产精品无码AV无码国产 | 欧美一区二区三区久久 | 91精品美女| 国产精品爱啪在线线免费观看 | 免费在线观看日韩 | 大咪咪av| 国产不卡视频在线播放 | 国产精品丝袜黑色高跟鞋的设计特点 | 午夜h视频| 国产女人18毛片18精品 | 黄片毛片在线免费观看 | 特级a毛片 | 国产wwwwww| 四季av中文字幕一区 | 国产一区中文 | 加勒比综合网 | 女性向av免费网站 | 国产午夜精品一区二区理论影院 | 日韩r级在线观看 | 亚洲www色 | 日本一本久草 | 丰满少妇久久久久久久 | 国产一区二区三区毛片 | 日日爽视频 | 亚洲黄色免费 | 成人激情av | 中文字幕日韩欧美一区二区三区 | 综合婷婷久久 | 高清二区 | 桃谷绘里香在线播放 | 欧美日韩色图 | 欧美国产日本 | 国产精品日韩欧美一区二区三区 | 国产无遮挡又黄又爽在线观看 |