關於iphone點擊readonly的input虛擬鍵盤不消失的情況

来源:http://www.cnblogs.com/shisufei/archive/2017/05/26/6909450.html
-Advertisement-
Play Games

今天遇到了一個比較棘手的問題,事情是這樣的: 咱有一個添加地址的頁面,大概長這樣: 收貨地址後那個“請選擇收貨地址”是一個readonly的input, 咱一進頁面,直接點擊這個“請選擇收貨地址”是完全看不出任何毛病的, 但是按照大家的習慣啊,當然是一個一個往下填, 這時問題就來了,安卓手機是正常的 ...


今天遇到了一個比較棘手的問題,事情是這樣的:

咱有一個添加地址的頁面,大概長這樣:

收貨地址後那個“請選擇收貨地址”是一個readonly的input,

咱一進頁面,直接點擊這個“請選擇收貨地址”是完全看不出任何毛病的,

但是按照大家的習慣啊,當然是一個一個往下填,

這時問題就來了,安卓手機是正常的,顯示這樣:

可蘋果手機不一樣了,

咱輸了手機號碼,點“請選擇收貨地址”,

這時候,本該關閉的虛擬鍵盤依然呆在屏幕上,彈出的地址選擇器部分顯示在虛擬鍵盤上方,整個頁面顯得擁擠不堪,(這裡沒法截圖啊!)

那麼,如何讓這個虛擬鍵盤關閉就成了一個燒腦的問題了,

於是嘗試了網上的各種辦法:

①給它加個 -webkit-user-select:none 的style,結果並沒有任何變化,pass

②給它加個disabled屬性,結果點擊的時候虛擬鍵盤確實沒有了,可地址選擇器也不出現了,pass

③那就吧input改成span吧?可是依然出現原來那個問題,在這裡終於發現了一個現象,當我們點擊這個“請選擇收貨地址”,游標居然還停在剛纔輸入手機號的那個框裡頭,這會兒有了點眉目了

④那接著③繼續加,在“請選擇收貨地址”的點擊事件里第一行加個this.focus();乖乖,還是不行,具體什麼情況記不清啦,pass

⑤於是接著百度了一下:終於在百度知道https://zhidao.baidu.com/question/1240497270717962459.html找到了答案,即

  嘗試讓獲取焦點的元素失去焦點,document.activeElement.blur();

同樣,是在“請選擇收貨地址”的點擊事件里第一行加的,一試,果然完美解決了,

接著又把span改回了原來的input,也運行正常!!!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 轉載請註明出處:http://www.cnblogs.com/Joanna-Yan/p/6878529.html 前面有講到Spring+SpringMVC+MyBatis深入學習及搭建(三)——MyBatis全局配置文件解析 1. 輸入映射 通過parameterType指定輸入參數的類型,類型可 ...
  • 一直都在用yii2做項目,有在用自動化配置,但是沒有自己去配置過。中午沒事去看了下yii的初始化代碼,發現都是php而已! yii2初始化項目代碼 所以,我們做項目肯定是可以用php做的,於是我新建了個文件夾,名為autoConfig,裡面創建了個init,裡面寫瞭如下代碼: 也就是一個非常簡單的自 ...
  • mybatis的參數傳遞以及resultType和resultMap的使用 ...
  • 《Spring源碼深度解析》從核心實現和企業應用兩個方面,由淺入深、由易到難地對Spring源碼展開了系統的講解,包括Spring的設計理念和整體架構、容器的基本實現、預設標簽的解析、自定義標簽的解析、bean的載入、容器的功能擴展、AOP、資料庫連接JDBC、整合MyBatis、事務、Spring ...
  • 需求分析: 有個廠家,下麵有很多代理商(商戶或門頭等),之前商戶進貨、庫存、銷售、客戶資料等記錄在excel表格中 或者無記錄,管理比較混亂,盈利情況不明。不能有效瞭解店鋪經營情況和客戶跟蹤記錄 廠家也不能實時瞭解下麵代理商的經營狀況和庫存情況 解決方案: 本系統角色主要分兩個層級:總管理(廠家), ...
  • 起因:開發中慢慢的學習使用es6,但是JavaScript需要瀏覽器來解析,而不是所有瀏覽器都支持es6,所以為了相容es6,需要第三方工具進行編譯es6。 工具:node,gulp,gulp-babel,babel-preset-es2015。 備註:只介紹基於node,gulp下的babel編譯 ...
  • HTML表單格式化 一、說明 用table佈局 二、效果 三、代碼 ...
  • 首先簡介一下http-server: http-server是一個簡單的零配置命令行http伺服器,他對於生產使用來說足夠強大,他是簡單和可刪節足以用於測試,足夠簡單易用,而且可用於本地開發 1、首先你要安裝node 2、然後可以通過npm來全局安裝 sudo cnpm install http-s ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...