基于VUE實(shí)現(xiàn)判斷設(shè)備是PC還是移動(dòng)端
實(shí)際開(kāi)發(fā)工作中會(huì)經(jīng)常遇到一個(gè)需求,就是判斷當(dāng)前登錄網(wǎng)頁(yè)的設(shè)備是PC還是移動(dòng),要求PC端和移動(dòng)端顯示的是不同的網(wǎng)頁(yè)內(nèi)容。
那么我們就需要對(duì)當(dāng)前登錄設(shè)備進(jìn)行判斷。
使用 navigator.userAgent 字符串檢測(cè)
我是在PC端開(kāi)發(fā)完接到要做移動(dòng)端的需求,而且移動(dòng)端只有一個(gè)頁(yè)面,我就統(tǒng)一放在了一個(gè)文件夾內(nèi)。首先在 app.vue 文件內(nèi),判斷當(dāng)前設(shè)備是pc端還是移動(dòng)端。
methods: { // 添加判斷方法 isMobile() { let flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i); return flag; }},mounted: { if(this.isMobile) { alert('移動(dòng)端'); this.$router.replace(’/pc_index’); }else { alert('pc端'); this.$router.replace(’/m_index’); }}
接下來(lái)就略微介紹一下這個(gè)方法,其中用到了 navigator.userAgent 。
這個(gè)方法會(huì)返回一個(gè)只讀的字符串,聲明了瀏覽器在發(fā)送 http 請(qǐng)求時(shí)的用戶(hù)代理頭的值。例如:
<script> document.write('用戶(hù)代理:' + navigator.userAgent)</script>// pc端輸出結(jié)果:用戶(hù)代理: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.88 Safari/537.36// 移動(dòng)端輸出結(jié)果:用戶(hù)代理: Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1
.match 方法用于在字符串內(nèi)檢索指定的值,或找到一個(gè)或多個(gè)正則表達(dá)式的匹配,返回值是檢索到的值。類(lèi)似的方法還有 indexOf()、laseIndexOf(),但是這兩個(gè)方法返回的是匹配到的值的位置。所以在判斷方法中使用.match方法匹配所有的移動(dòng)端型號(hào),最后加的 /i 是表示不區(qū)分大小寫(xiě)。
使用 window.matchMedia() 檢測(cè)
也就是利用媒體查詢(xún)的方式進(jìn)行判斷。
window.matchMedia 方法會(huì)返回一個(gè)新的 mediaQueryList 對(duì)象,表示指定的媒體查詢(xún)字符串解析后的結(jié)果。例如:
var result = window.matchMedia('(min-width: 400px)').matches;console.log(result) //true
window.matchMedia 方法會(huì)返回兩個(gè)參數(shù),一個(gè)是 media,就是查詢(xún)的語(yǔ)句內(nèi)容。另一個(gè)是 matches,是返回的結(jié)果,為 boolean 類(lèi)型。
根據(jù)當(dāng)前設(shè)備的視口寬度判斷是否是移動(dòng)端設(shè)備。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. UTF8轉(zhuǎn)成GB2312亂碼問(wèn)題解決方案2. Java進(jìn)行Appium自動(dòng)化測(cè)試的實(shí)現(xiàn)3. php中PHPUnit框架實(shí)例用法4. 詳細(xì)總結(jié)Java for循環(huán)的那些坑5. css進(jìn)階學(xué)習(xí) 選擇符6. ajax實(shí)現(xiàn)頁(yè)面的局部加載7. 詳解CSS偽元素的妙用單標(biāo)簽之美8. 如何利用Python matplotlib繪制雷達(dá)圖9. 新手學(xué)python應(yīng)該下哪個(gè)版本10. Spring中@Value讀取properties作為map或list的操作

網(wǎng)公網(wǎng)安備