微信內置瀏覽器中,點擊下拉框出現頁面亂跳轉現象(iphone)

来源:http://www.cnblogs.com/yimi8426/archive/2016/01/04/5099039.html
-Advertisement-
Play Games

微信內置瀏覽器中,點擊下拉框出現頁面亂跳轉現象(iphone)前言:這是小菜博客的第三篇文章。一直認為自己可以表達的東西太過簡單,難以上臺面,總是吝嗇地不肯寫。就算是寫,也不知道從何開始。在同事的鼓勵下,終於跨出了第一步。初期階段,寫文章不一定是非要給他人看,當作自己的學習筆記也是一個不錯的選擇。另...


微信內置瀏覽器中,點擊下拉框出現頁面亂跳轉現象(iphone)

前言:

      這是小菜博客的第三篇文章。一直認為自己可以表達的東西太過簡單,難以上臺面,總是吝嗇地不肯寫。就算是寫,也不知道從何開始。在同事的鼓勵下,終於跨出了第一步。初期階段,寫文章不一定是非要給他人看,當作自己的學習筆記也是一個不錯的選擇。另外,在這幾次的寫作中發現,寫技術博客本身也是需要一定的表達能力。好了,廢話不多說,開始講講在項目中碰到的實際問題吧。

情景再現:

      正當開心地收拾東西準備下班的時候,測試部的姑娘跑過來提了一個bug: “iphone5下,點擊輸入框或下拉框時,底部菜單無法固定,出現頁面亂跳轉現象,而安卓機並沒有這個問題”由於項目比較急,小菜只能乖乖留下解決問題。再次測試之後,小菜逐一排查了可能性原因(正式版和測試版代碼不一致,頁面HTML代碼錯亂,css代碼錯誤),但都未能解決問題。一個簡單的select,怎麼就出現問題了呢?百思不得其解。(至今也沒有找到問題根源)

      找不出問題根源,只能先看看有沒有解決方案。經過多次調試,捕獲select動作,找到了一個解決方案。原理很簡單:利用div來模擬select。

解決方案:

      思路也是比較清晰的。頁面中有兩個html結構,一是select代碼照常寫(一開始處於隱藏狀態display:none),二是被模擬的div(一開始處於顯示狀態)。當點擊div時: 

  1. 出現select下拉框
  2. 隱藏底部菜單
  3. 將讀取的option值給被模擬的div,其模擬核心代碼可下載VisualSelect.js
  4. 賦值之後,恢復開始狀態,顯示底部菜單

以下是代碼:

【html代碼】

<div class=”visualSelect” >商行</div>
<select class=”round” style=”display:none;”>
    <option value=”1”>國股</option>
    <option value=”2”>商行</option>
    <option value=”3”>其他</option>
</select>

【css代碼】

.round { border-radius: 4px;}
.visualSelect {
    width: 100%;
    padding: .45rem .5rem .25rem .75rem;
    margin-bottom: .875rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    color: #bbb;
}

js代碼】

註:由於該問題只存在於小屏幕iphone,android手機並沒有問題,因此最好判斷機型。這裡對iphone機型作了統一判斷,並未詳細區分。要是有興趣的,可以自行詳細判別。

var agent = navigator.userAgent;
if ( agent.indexOf(“iPhone”) > -1) {  
    $(“select”).VisualSelect();    //調用插件即可
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 全選反選 布爾屬性,只要name即可,...
  • table切換 1 2 3 4 5
  • <h2 CSS 尺寸 (Dimension) 實例</h2 <h3 CSS 實例</h3 CSS 背景實例 CSS 文本實例 CSS 字體(font)實例 CSS 邊框(border)實例 CSS 外邊距 (margin) 實例 CSS 內邊距 (padding) 實例 CSS 列表實例 CSS ....
  • jq-get方法test.json文件:[{"name": "艷艷","pass": "123456","age": "26"},{"name": "張三","pass": "88888888","age": "28"},{"name": "李四","pass": "111111"
  • $("p").eq(0).css("color") //因為eq(num)返回的是個jq對象,所以可以用jq的方法css使用get來獲得第一個p標簽的color值;$("p").get(0).style.color //因為get(num)返回的是個html對象,所以要使用傳統的HTML對象方法,j...
  • 獲取JavaScript 的時間使用內置的Date函數完成var mydate = new Date();mydate.getYear(); //獲取當前年份(2位)mydate.getFullYear(); //獲取完整的年份(4位,1970-????)mydate.getMonth(); //獲...
  • [1]整數 [2]浮點數 [3]舍入誤差 [4]數值範圍 [5]數值轉換 [6]繼承的方法 [7]其他方法
  • JavaScript原型及原型鏈詳解一.普通對象與函數對象 JavaScript中,萬物皆對象!但對象也是有區別的。分為普通對象和函數對象,Object,Function是JS自帶的函數對象。下麵舉例說明 functionf1(){}; varf2=function(){}; varf3=n...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...