1. Routing Guard
//All routing requests will pass through the routing guard, router.beforeEach((to, from, next) => { //Access link such as: http://localhost/page/detail/IUKGEQ/108/9933/32279/8 //The access path is: /page/detail/IUKGEQ/108/9933/32279/8 let toUrl = to.path; //This route request is released next(); }); 2. Determine the clientnavigator.userAgent : Gets the value of the user agent header used by the browser for HTTP requests if (typeof window !== 'undefined' && typeof window.navigator !== 'undefined') { if(/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)) { //Processing business logic on mobile side}else{ //Processing business logic on the computer side} } 3. Regular Expression (JS)grammar
Modifiers
search()The search() method is used to search for a specified substring in a string, or to search for a substring that matches a regular expression, and return the starting position of the substring. If not, returns **-1**. // Case insensitive var index = 'Hello World!'.search(/world/i); replace()The replace() method is used to replace some characters in a string with other characters, or to replace a substring that matches a regular expression. var txt = 'Microsoft'.replace("Microsoft","World"); test()The test() method is used to check whether a string matches a pattern. If the string contains matching text, it returns true, otherwise it returns false var flag = /Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent); exec()The exec() method is used to retrieve matches of a regular expression within a string. This function returns an array containing the matching results. If no match is found, the return value is null. var matchParams = /(\d{1,3})\/(\d{4,6})\/(\d{4,6})/.exec('/page/detail/IUKGEQ/108/9933/32279/8') Regular syntax reference: https://www.runoob.com/regexp/regexp-syntax.html 4. Source code:export default ({ app }) => { app.router.beforeEach((to, from, next) => { if (typeof window !== 'undefined' && typeof window.navigator !== 'undefined') { if(!/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)) { //If accessed from a computer, next() will be released directly; }else{ var sCode = ''; let toUrl = to.path; //Identifier acquisition method 1: Get from the request link //For example: /page/detail/IUKGEQ/108/9933/32279/8 //For example: /IUKGEQ //Regular expression to extract the six uppercase letters in the connection let matchArr = toUrl.match('\/([AZ]{6})'); if((sCode=='' || sCode == null || sCode == undefined) && matchArr != null){ sCode = matchArr[1]; } //Identification acquisition method 2: initiate a request to obtain the Code //For example: /swpu let matchArr2 = toUrl.match('\/([az]{3,})'); if((sCode=='' || sCode == null || sCode == undefined) && matchArr2 != null){ var param = matchArr2[1]; getSInfo2(param) .then(res => { if (res.data.code) { sCode = res.data.code; //Route jump mobileRouteCombine(toUrl,sCode); } else { // Can't find code next();//release} }) .catch(err => { next(); //release }); } //If the above two methods cannot retrieve the code, just release it if(sCode=='' || sCode == null || sCode == undefined){ next(); return; }else{ //Route jump mobileRouteCombine(toUrl,sCode); } } } next(); }) } /** * Mobile routing reorganization* @param {URL address to be visited} toUrl * @param [code] sCode */ function mobileRouteCombine(toUrl,sCode){ var wxHomeUrl = conf.weixin + '/build/index.html?scode=' + sCode + '#/'; // If toUrl is in the form of /IUKGEQ, it will directly jump to the WeChat homepage if(toUrl.length <= 7){ location.href = wxHomeUrl; } //Article listif(toUrl.indexOf('/page/list/') != -1){ let matchParams = toUrl.match('(\\d{1,3})\/(\\d{4,6})'); let catId = matchParams[2]; let versionId = matchParams[1]; //version id var url = wxHomeUrl + 'articleList?catId=' + catId; location.href = url; } //Article detailsif(toUrl.indexOf('/page/detail/') != -1){ let matchParams = toUrl.match('(\\d{1,3})\/(\\d{4,6})\/(\\d{4,6})'); let infoId = matchParams[3]; let catId = matchParams[2]; let versionId = matchParams[1]; //version id var url = wxHomeUrl + 'articleDetail?infoId=' + infoId + '&catId=' + catId; location.href = url; } } This is the end of this article about redirecting PC address to mobile terminal in vue. For more relevant vue address redirection content, please search 123WORDPRESS.COM’s previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: How to keep running after exiting Docker container
>>: Analysis of the HTML writing style and reasons of experienced people
Article mind map Why use master-slave replication...
The order in which objects call methods: If the m...
The code under the easyui framework is as follows...
Overview The cloud platform customer's server...
When using a virtual machine, you may find that t...
Vue card flip carousel display, while switching d...
In projects, batch operation statements are often...
· 【Scene description】 After HTTP1.1, the HTTP pro...
Table of contents Preface 1. Style penetration 1....
Table of contents 1. Handwritten instanceof 2. Im...
The vue mobile terminal determines the direction ...
A new window opens. Advantages: When the user cli...
1. Computed properties and listeners 1.1 Computed...
The official document states: By injecting the ro...
Because the data binding mechanism of Vue and oth...