欧美vvv,亚洲第一成人在线,亚洲成人欧美日韩在线观看,日本猛少妇猛色XXXXX猛叫

新聞資訊

    前言

    在移動端的web開發中,一提起輸入框,程序猿(媛)肯定有很多可以吐槽的點。

    在輸入框的運用中,小編也是很心累呀~

    不過,經過我 潛(cai)心(keng)研(jiao)究(xun),也算是了解了它的脾性... ...

    特別鳴謝:周涵,家興等

    正文這里開始 ? — — — — — — — —

    問題探究1. ios中,輸入框獲得焦點時,頁面輸入框被遮蓋,定位的元素位置錯亂:

    當頁input存在于吸頂或者吸底元素中時,用戶點擊輸入框,輸入法彈出后,fiexd失效,頁面中定位好的元素隨屏幕滾動。

    針對這個問題,我們一起來看下以下幾種方案:

    方案一: Web API 接口 : 的應用,將input輸入框顯示在可視區域。

    // 輸入框獲得焦點時,元素移動到可視區域
    inputOnFocus(e) { 
       setTimeout(function(){
           e.target.scrollIntoView(true); 
    // true:元素的頂端將和其所在滾動區的可視區域的頂端對齊; false:底端對齊。 
    },200); // 延時 == 鍵盤彈起需要時間
    }

    qq輸入什么字符變表情_bat腳本語法 字符輸入_獲得輸入的字符的位置

    一行代碼獲得輸入的字符的位置,輕松搞定,輸入框就乖乖的出現在你眼前了。

    不過有點小缺陷:頁面過長時,由于fixed失效,輸入框依然也會跟著頁面滑走。

    這時,我們需要一個固定的輸入框......

    方案二:在輸入框獲得焦點時,將頁面滑動到最底部,避免fixed導致的頁面亂飛,并且保證input在最底部。

    var timer;
    // 輸入框獲得焦點時,將元素設置為position:static,設置timer
    inputOnFocus(e) { 
       e.target.style.className = 'input input-static'; 
       timer = setInterval(
    function() { 
               document.body.scrollTop = document.body.scrollHeight 
    }, 100)
    };
    // 輸入框失去焦點時,將元素設置為 position:fixed,清除timer
    inputOnbulr(e) { 
       e.target.parentNode.className = 'input input-fixed';
       clearInterval(timer)
    

    獲得輸入的字符的位置_qq輸入什么字符變表情_bat腳本語法 字符輸入

    };

    效果如下圖

    當獲得焦點彈出虛擬鍵盤后,input輸入框會一直緊貼鍵盤頂部。如果,你的頁面彈出輸入法后不需要滑動查看其他內容,那么你對這種方案應該很中意。

    But獲得輸入的字符的位置,可能你做的是一個類似聊天的頁面,需要在回復時,查看歷史消息,那么,請你繼續往下看

    方案三:將頁面進行拆分: 頁面(main) = 內容() + 輸入框()+ 其他()

    原理 : main. = .. ;

    絕對定位,進行內部滾動 -y: ;

    可保證在頁面最底部。

    .main { position: relative; height: 100%; } 
    .sectionA { box-sizing: border-box; padding-bottom: 60px; height: 100%; overflow-y: scroll; -webkit-overflow-scrolling: touch //為了使滾動流暢,sectionA 添加屬性 } 
    .sectionB { position: absolute; height: 60px; overflow: hidden; left: 0; right: 0; bottom: 0; }

    純css3打造,可以滾動,可以固定位置,基本滿足大部分布局需要。

    2. IOS 中單行輸入框輸入內容長被遮蓋,不能顯示全部,且不能左右滑動。

    這個是IOS的一個bug,可以考慮用 替換 input,設置一行的高,進行上下滾動查看。(其他方案可以參看下面 第 6 點)

    3. 獲得焦點時,光標消失或錯位:

    獲得輸入的字符的位置_bat腳本語法 字符輸入_qq輸入什么字符變表情

    --user-:none 導致 input 框在 iOS 中無法輸入,光標不出現,設置如下

    user-select:text;
    -webkit-user-select:text;

    利用 使當前元素出現到指定位置,避免光標錯位,設置如下:

    e.target.scrollIntoView(true); 
    e.target.scrollIntoViewIfNeeded();

    4. 進入頁面如何自動獲取焦點,彈出軟鍵盤?5.隨文字輸入,輸入框寬度自適應。

     onkeyPress(e) {
    const testLength = e.target.value.length;
       e.target.style.width = `${testLength*8+10}px`
    }

    這種方案基本滿足自動獲取效果。

    * 8 英文字符, * 16中文字符, +10為后邊光標預留位置。 這種方案顯然不適用于對精確度有很高要求的需求。

    6. 介紹一個屬性:,模擬輸入時動態獲取寬高

    (1)div設置=true 可以將此元素變成可輸入狀態。

    qq輸入什么字符變表情_獲得輸入的字符的位置_bat腳本語法 字符輸入

    (2)想要變成input輸入框,利用css模擬輸入框的樣式

    .inputContent{
     color:#444;
     border:#999 solid 1px;
     border-radius: 3px;
     padding: 5px 10px;
     box-sizing: border-box;
     min-width:50px;
     max-width: 300px;
     background: #ffffff;
    }

    這里配合min-width,max-width 效果更真實。

    (3)點擊div可以彈出軟鍵盤,但是無法輸入內容,需要設置屬性,如下

    .inputContent{
     user-select:text;
    -webkit-user-select:text;
    }

    qq輸入什么字符變表情_bat腳本語法 字符輸入_獲得輸入的字符的位置

    這樣就完成一個可以根據獲取輸入內容來動態來調節寬高。

    (這里是一個gif圖)

    還可以利用js模擬等,這里就不展開了

    7.其他問題及解決

    --user-:none 導致的,可以這樣解決

    *:not(input,textarea) {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    }

    // 使用偽類 
    input::-webkit-input-placeholder,
    input::-moz-placeholder,
    input::-ms-input-placeholder {
    ...style
     text-align: center;
    }

    好了,就寫到這了,希望看過后對你能有幫助。

    輸入框中的坑還是很多了,本文也難免會有有含蓋不全的情況,歡迎小伙伴們給我們留言,共同探討。

網站首頁   |    關于我們   |    公司新聞   |    產品方案   |    用戶案例   |    售后服務   |    合作伙伴   |    人才招聘   |   

友情鏈接: 餐飲加盟

地址:北京市海淀區    電話:010-     郵箱:@126.com

備案號:冀ICP備2024067069號-3 北京科技有限公司版權所有