JS如何實(shí)現(xiàn)網(wǎng)站中PC端和手機(jī)端自動(dòng)識(shí)別并跳轉(zhuǎn)對(duì)應(yīng)的代碼
1. 代碼場(chǎng)景:
描述:在項(xiàng)目中,一般我們會(huì)使用響應(yīng)式布局的方式或者借助bootstrap等插件來(lái)做響應(yīng)式的網(wǎng)站。但是根據(jù)業(yè)務(wù)的需求,手機(jī)端可能會(huì)在功能上精簡(jiǎn)很多,我們也會(huì)寫(xiě)兩套代碼,分別用來(lái)實(shí)現(xiàn)PC端和手機(jī)端的功能。此時(shí),就存在一個(gè)問(wèn)題。項(xiàng)目在部署的時(shí)候只會(huì)使用一個(gè)地址,不會(huì)針對(duì)手機(jī)和PC端代碼分別進(jìn)行部署。這個(gè)時(shí)候就需要我們通過(guò)去識(shí)別視口分辨率的大小,來(lái)自動(dòng)去跳轉(zhuǎn)對(duì)應(yīng)的代碼。
2. 實(shí)現(xiàn)方式:
目前網(wǎng)上有很多的方法用來(lái)實(shí)現(xiàn)PC端和手機(jī)端的代碼跳轉(zhuǎn),但我只用了一種實(shí)現(xiàn)方式。其他的暫時(shí)還沒(méi)有嘗試,希望可以跟大家學(xué)到更多的解決方案。在此特別感謝<<--老蔣部落-->>的方法給予了我很大的幫助。
此處貼出當(dāng)前的JS代碼:
<script type="text/javascript"> function mobilePcRedirect() { var sUserAgent= navigator.userAgent.toLowerCase(); var bIsIpad= sUserAgent.match(/ipad/i) == "ipad"; var bIsIphoneOs= sUserAgent.match(/iphone os/i) == "iphone os"; var bIsMidp= sUserAgent.match(/midp/i) == "midp"; var bIsUc7= sUserAgent.match(/rv:1.2.3.4/i) == "rv:1.2.3.4"; var bIsUc= sUserAgent.match(/ucweb/i) == "ucweb"; var bIsAndroid= sUserAgent.match(/android/i) == "android"; var bIsCE= sUserAgent.match(/windows ce/i) == "windows ce"; var bIsWM= sUserAgent.match(/windows mobile/i) == "windows mobile"; if (bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) { window.location.href= '手機(jī)端跳轉(zhuǎn)頁(yè)面URL'; } else { window.location= 'PC端跳轉(zhuǎn)頁(yè)面URL'; } }; mobilePcRedirect(); </script>
將此方法分別寫(xiě)在手機(jī)端和PC端公共的Common.js中,然后在對(duì)應(yīng)位置寫(xiě)入對(duì)應(yīng)的路徑即可。
例如:手機(jī)端公共JS中代碼如下
// 實(shí)現(xiàn)網(wǎng)站自動(dòng)跳轉(zhuǎn)電腦PC端與手機(jī)端不同頁(yè)面 function mobilePcRedirect() { var sUserAgent= navigator.userAgent.toLowerCase(); var bIsIpad= sUserAgent.match(/ipad/i) == "ipad"; var bIsIphoneOs= sUserAgent.match(/iphone os/i) == "iphone os"; var bIsMidp= sUserAgent.match(/midp/i) == "midp"; var bIsUc7= sUserAgent.match(/rv:1.2.3.4/i) == "rv:1.2.3.4"; var bIsUc= sUserAgent.match(/ucweb/i) == "ucweb"; var bIsAndroid= sUserAgent.match(/android/i) == "android"; var bIsCE= sUserAgent.match(/windows ce/i) == "windows ce"; var bIsWM= sUserAgent.match(/windows mobile/i) == "windows mobile"; if (bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) { console.log("手機(jī)端跳轉(zhuǎn)頁(yè)面URL"); } else { console.log("PC端跳轉(zhuǎn)頁(yè)面URL"); // 注:此時(shí)寫(xiě)入的是PC端首頁(yè)跳轉(zhuǎn)路徑 window.location.href = getBasePath() + "/education/new_index.html"; } }; mobilePcRedirect();
反之,PC端公共JS中同樣的寫(xiě)法即可。
3. 拓展內(nèi)容(如何獲取項(xiàng)目的根路徑?)
獲取項(xiàng)目名稱(chēng):
/** * 獲取項(xiàng)目名稱(chēng) 如:/video_learning **/ function getProjectName() { var strPath = window.document.location.pathname; var postPath = strPath.substring(0,strPath.substr(1).indexOf('/')+1); return postPath; }
獲取項(xiàng)目全路徑:
/** * 獲取項(xiàng)目全路徑 如:http://localhost:8080/video_learning * */ function getBasePath(){ //獲取當(dāng)前網(wǎng)址 var curWwwPath=window.document.location.href; //獲取主機(jī)地址之后的目錄 var pathName=window.document.location.pathname; var pos=curWwwPath.indexOf(pathName); //獲取地址到端口號(hào) var localhostPath=curWwwPath.substring(0,pos); //項(xiàng)目名 var projectName=pathName.substring(0,pathName.substr(1).indexOf('/')+1); return (localhostPath+projectName); }
本次分享已完成,大家若有更好的方法或者意見(jiàn)歡迎指正學(xué)習(xí)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JS前端開(kāi)發(fā)判斷是否是手機(jī)端并跳轉(zhuǎn)操作(小結(jié))
- JS跳轉(zhuǎn)手機(jī)站url的若干注意事項(xiàng)
- js根據(jù)手機(jī)客戶(hù)端瀏覽器類(lèi)型,判斷跳轉(zhuǎn)官網(wǎng)/手機(jī)網(wǎng)站多個(gè)實(shí)例代碼
- 基于JavaScript代碼實(shí)現(xiàn)pc與手機(jī)之間的跳轉(zhuǎn)
- js判斷手機(jī)訪(fǎng)問(wèn)或者PC的幾個(gè)例子(常用于手機(jī)跳轉(zhuǎn))
- 兩款JS腳本判斷手機(jī)瀏覽器類(lèi)型跳轉(zhuǎn)WAP手機(jī)網(wǎng)站
- JS腳本根據(jù)手機(jī)瀏覽器類(lèi)型跳轉(zhuǎn)WAP手機(jī)網(wǎng)站(兩種方式)
- JSP中實(shí)現(xiàn)判斷客戶(hù)端手機(jī)類(lèi)型并跳轉(zhuǎn)到app下載頁(yè)面
- 百度判斷手機(jī)終端并自動(dòng)跳轉(zhuǎn)js代碼及使用實(shí)例
- 手機(jī)平板等移動(dòng)端適配跳轉(zhuǎn)URL的js代碼
- JS自動(dòng)跳轉(zhuǎn)手機(jī)移動(dòng)網(wǎng)頁(yè)的實(shí)現(xiàn)方法
相關(guān)文章
JS首屏加載時(shí)間優(yōu)化的解決方法總結(jié)
首屏加載時(shí)間是一個(gè)衡量網(wǎng)頁(yè)性能和用戶(hù)體驗(yàn)的關(guān)鍵指標(biāo),這個(gè)問(wèn)題無(wú)論是在面試中還是在項(xiàng)目開(kāi)發(fā)中都占有極其高的權(quán)重,本文為大家整理了幾種JS中優(yōu)化首屏加載時(shí)間的方法,希望對(duì)大家有所幫助2024-02-02js實(shí)現(xiàn)iPhone界面風(fēng)格的單選框和復(fù)選框按鈕實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)iPhone界面風(fēng)格的單選框和復(fù)選框按鈕,涉及javascript動(dòng)態(tài)操作頁(yè)面元素樣式的相關(guān)技巧,非常美觀(guān)大方,需要的朋友可以參考下2015-08-08微信小程序webview中監(jiān)聽(tīng)返回按鈕實(shí)現(xiàn)步驟
在微信小程序中webview返回鍵是一個(gè)非常實(shí)用的功能,它允許用戶(hù)在嵌入的網(wǎng)頁(yè)中返回到上一個(gè)頁(yè)面,這篇文章主要給大家介紹了微信小程序webview中監(jiān)聽(tīng)返回按鈕的實(shí)現(xiàn)步驟,需要的朋友可以參考下2024-08-08js 獲取坐標(biāo) 通過(guò)JS得到當(dāng)前焦點(diǎn)(鼠標(biāo))的坐標(biāo)屬性
通過(guò)JS得到當(dāng)前焦點(diǎn)的坐標(biāo),如何實(shí)現(xiàn),接下來(lái)詳細(xì)介紹實(shí)現(xiàn)步驟,有需要的朋友可以參考下2013-01-01JavaScript導(dǎo)出CSV文件不完整的問(wèn)題解決方法
在JavaScript中處理CSV文件時(shí),需要特別注意一些特殊字符,例如逗號(hào)、雙引號(hào)、換行符等,這些字符可能會(huì)影響CSV文件的解析,導(dǎo)致數(shù)據(jù)錯(cuò)亂,所以本文給大家介紹了如何解決JavaScript導(dǎo)出CSV文件不完整的問(wèn)題,需要的朋友可以參考下2024-06-06JavaScript使用高階生成器進(jìn)行過(guò)濾以生成素?cái)?shù)
生成器大家都知道是怎么一回事,但是高階生成器又是什么東西呢,下面小編就來(lái)為大家簡(jiǎn)單介紹一下如何使用高階生成器進(jìn)行過(guò)濾以生成素?cái)?shù)吧2024-02-02js中int和string數(shù)據(jù)類(lèi)型互相轉(zhuǎn)化實(shí)例
在本篇文章里小編給大家分享了關(guān)于js中int和string數(shù)據(jù)類(lèi)型互相轉(zhuǎn)化實(shí)例和代碼,需要的朋友們學(xué)習(xí)下。2019-01-01js數(shù)組方法reduce經(jīng)典用法代碼分享
本文給大家整理了很多關(guān)于js數(shù)組方法reduce的經(jīng)典代碼片段,能夠讓大家更好的理解reduce的實(shí)例用法,一起學(xué)習(xí)下吧。2018-01-01