百度判斷手機終端并自動跳轉js代碼及使用實例
百度目前為站長提供了判斷手機終端類型并自動實現(xiàn)跳轉的js腳本,極大的方便了廣大站長及web開發(fā)人員。其js腳本的使用方法極其簡單。
<script src="http://siteapp.baidu.com/static/webappservice/uaredirect.js" type="text/javascript"></script>
<SCRIPT type=text/javascript>uaredirect("手機站","WEB站");</SCRIPT>
其中最為核心的js腳本格式化代碼如下所示:
function uaredirect(f) {
try {
if (document.getElementById("bdmark") != null) {
return
}
var b = false;
if (arguments[1]) {
var e = window.location.host;
var a = window.location.href;
if (isSubdomain(arguments[1], e) == 1) {
f = f + "/#m/" + a;
b = true
} else {
if (isSubdomain(arguments[1], e) == 2) {
f = f + "/#m/" + a;
b = true
} else {
f = a;
b = false
}
}
} else {
b = true
}
if (b) {
var c = window.location.hash;
if (!c.match("fromapp")) {
if ((navigator.userAgent.match(/(iPhone|iPod|Android|ios)/i))) {
location.replace(f)
}
}
}
} catch(d) {}
}
function isSubdomain(c, d) {
this.getdomain = function(f) {
var e = f.indexOf("://");
if (e > 0) {
var h = f.substr(e + 3)
} else {
var h = f
}
var g = /^www\./;
if (g.test(h)) {
h = h.substr(4)
}
return h
};
if (c == d) {
return 1
} else {
var c = this.getdomain(c);
var b = this.getdomain(d);
if (c == b) {
return 1
} else {
c = c.replace(".", "\\.");
var a = new RegExp("\\." + c + "$");
if (b.match(a)) {
return 2
} else {
return 0
}
}
}
};
建議站長及web開發(fā)人員使用如下壓縮后的js腳本
function uaredirect(f){try{if(document.getElementById("bdmark")!=null){return}var b=false;if(arguments[1]){var e=window.location.host;var a=window.location.href;if(isSubdomain(arguments[1],e)==1){f=f+"/#m/"+a;b=true}else{if(isSubdomain(arguments[1],e)==2){f=f+"/#m/"+a;b=true}else{f=a;b=false}}}else{b=true}if(b){var c=window.location.hash;if(!c.match("fromapp")){if((navigator.userAgent.match(/(iPhone|iPod|Android|ios)/i))){location.replace(f)}}}}catch(d){}}function isSubdomain(c,d){this.getdomain=function(f){var e=f.indexOf("://");if(e>0){var h=f.substr(e+3)}else{var h=f}var g=/^www\./;if(g.test(h)){h=h.substr(4)}return h};if(c==d){return 1}else{var c=this.getdomain(c);var b=this.getdomain(d);if(c==b){return 1}else{c=c.replace(".","\\.");var a=new RegExp("\\."+c+"$");if(b.match(a)){return 2}else{return 0}}}};
PS:在此小編為大家推薦幾款javascript格式化美化與壓縮工具,類似上述的百度跳轉代碼壓縮與格式化就可使用下述工具實現(xiàn):
C語言風格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
在線JavaScript代碼美化、格式化工具:
http://tools.jb51.net/code/js
JavaScript代碼美化/壓縮/格式化/加密工具:
http://tools.jb51.net/code/jscompress
JavaScript在線壓縮工具:
http://tools.jb51.net/code/js_yasuo
JavaScript在線格式化工具(基于beautify.js插件):
http://tools.jb51.net/code/js_beautify
- JS如何實現(xiàn)網(wǎng)站中PC端和手機端自動識別并跳轉對應的代碼
- JS前端開發(fā)判斷是否是手機端并跳轉操作(小結)
- JS跳轉手機站url的若干注意事項
- js根據(jù)手機客戶端瀏覽器類型,判斷跳轉官網(wǎng)/手機網(wǎng)站多個實例代碼
- 基于JavaScript代碼實現(xiàn)pc與手機之間的跳轉
- js判斷手機訪問或者PC的幾個例子(常用于手機跳轉)
- 兩款JS腳本判斷手機瀏覽器類型跳轉WAP手機網(wǎng)站
- JS腳本根據(jù)手機瀏覽器類型跳轉WAP手機網(wǎng)站(兩種方式)
- JSP中實現(xiàn)判斷客戶端手機類型并跳轉到app下載頁面
- 手機平板等移動端適配跳轉URL的js代碼
- JS自動跳轉手機移動網(wǎng)頁的實現(xiàn)方法
相關文章
JS 判斷某變量是否為某數(shù)組中的一個值的3種方法(總結)
下面小編就為大家?guī)硪黄狫S 判斷某變量是否為某數(shù)組中的一個值的3種方法(總結)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07詳解微信小程序自定義組件的實現(xiàn)及數(shù)據(jù)交互
這篇文章主要介紹了微信小程序自定義組件的實現(xiàn)及數(shù)據(jù)交互,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07mpvue微信小程序多列選擇器用法之省份城市選擇的實現(xiàn)
這篇文章主要給大家介紹了關于mpvue微信小程序多列選擇器用法之省份城市選擇實現(xiàn)的相關資料,文中通過示例代碼以及圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-03-03javascript設計模式 – 適配器模式原理與應用實例分析
這篇文章主要介紹了javascript設計模式 – 適配器模式,結合實例形式分析了javascript適配器模式相關概念、原理、用法及操作注意事項,需要的朋友可以參考下2020-04-04