


How does js determine whether the user is accessing on PC or mobile terminal_javascript skills
Recently we have been busy with our team's project "Coffee Wings", in which we provide an excellent experience for mobile platforms. With the booming development of the Android platform. Not only has it driven the domestic smartphone industry, but many domestic developers have also begun to join the wave of Android mobile terminals. If there are many big Internet waves you missed. Then you absolutely can’t miss this Android wave. At present, we have developed mobile terminals and Android clients for "Wings of Coffee". If you use a mobile phone with Android or IOS operating system, you can directly visit the domain name www.sygxy.cn to view the mobile terminal effects. At the same time, the Android client has been put on application malls such as Tencent’s “App Store” and “Baidu Mobile Assistant”. You can directly search for "Coffee Wings" to download. Without any promotion, it has only been on the shelves for a week and has already received more than 100 downloads.
If you need to optimize the mobile terminal, what you must do is to determine what the client's access device is. Based on the judgment results, the unresolved domain name address is returned, and then different CSS files are loaded.
The judgment method we use is based on the user-agent value. Use the userAgent property of the Navigator object in the javascript framework. There is no public standard for the navigator object, but it is supported by all browsers on the market. Use the userAgent attribute to return the value of the user-agent header sent by the client to the server. There is a User-Agent in the header information. Its function is to tell the server what browser the user's client is and the operating system information. Use regular expressions to obtain the user-agent value. It is judged against the local value. This matching value can be a mobile operating system such as Android, ios, or the name of the browser. If there is a match, it will jump. Otherwise, it will not jump and go directly to the PC homepage.
For specific code implementation, in order to improve the portability of the website, we use JavaScript scripting language. In the author’s opinion, there are two benefits of using this technology
1: It can improve the portability of the website. If in future web projects, our team needs to add the effect of mobile terminals again, it can be easily Easily introduce this part of the JS code and make a judgment. Improve future work efficiency.
2: The second point is to facilitate the loading of Web programs on different interfaces, and whether to introduce this part of the mobile terminal judgment code.
Specific implementation:
We separate the script for judging access. If a page needs to be judged by the client terminal, we will directly use <script></script> to introduce it on the page. Script program, the specific judgment code is as follows:
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|Windows Phone)/i))){location.replace(f)}}}}catch(d)
{
}

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The pc side is a computer. The full name of pc is Personal Computer, which means personal computer or personal computer in Chinese; PC refers to the port in the network world that can be connected to the computer host. It is a computer-based interface system, which is different from the mobile phone interface system.

The full name of pc is Personal Computer, which means personal computer or personal computer in Chinese; PC refers to the port in the network world that can be connected to the computer host. It is a computer-based interface system, which is different from the mobile phone interface system.

In mobile development, we often encounter the problem of multi-finger touch. When users use multiple fingers to swipe or zoom the screen on a mobile device, how to accurately recognize and respond to these gestures is an important development challenge. In Vue development, we can take some measures to solve the problem of multi-finger touch on the mobile terminal. 1. Use the vue-touch plug-in vue-touch is a gesture plug-in for Vue, which can easily handle multi-finger touch events on the mobile side. We can install vue-to via npm

How to use mobile gesture operations in Vue projects With the popularity of mobile devices, more and more applications need to provide a more friendly interactive experience on the mobile terminal. Gesture operation is one of the common interaction methods on mobile devices, which allows users to complete various operations by touching the screen, such as sliding, zooming, etc. In the Vue project, we can implement mobile gesture operations through third-party libraries. The following will introduce how to use gesture operations in the Vue project and provide specific code examples. First, we need to introduce a special

With the popularity of mobile devices, using Vue for mobile development has become a common choice. However, we often face a problem during mobile development, which is double-clicking to zoom in. This article will focus on this problem and discuss how to solve the specific method of double-click amplification on the mobile terminal in Vue development. The double-click enlargement problem on mobile devices occurs mainly because the mobile device automatically enlarges the zoom ratio of the web page when double-clicking on the touch screen. For general web development, this kind of double-click to enlarge is usually beneficial because it can

The PC side usually refers to a personal computer, including desktop computers, laptops, etc., which is one of the commonly used devices for people. The PC side generally refers to a collection of operating systems and applications running on a computer. It has powerful computing processing capabilities and a human-computer interaction interface. It is usually used for various office, entertainment, design, programming and other activities. .

Method of implementing mobile map positioning function using Python and Baidu Map API. With the development of mobile Internet, map positioning function has become more and more common in mobile applications. Python, as a popular programming language, can also implement mobile map positioning functions by using Baidu Map API. The following will introduce the steps to implement the map positioning function using Python and Baidu Map API, and provide corresponding code examples. Step 1: Apply for Baidu Map API Key Before starting, we first need to apply

How to solve the stuck problem of mobile gesture zooming pages in Vue development. In recent years, the popularity of mobile applications has made gesture operations an important way of user interaction. In Vue development, implementing the gesture zoom function on the mobile terminal often encounters the problem of page lag. This article will explore how to solve this problem and provide some optimization strategies. Understand the principle of gesture scaling. Before solving the problem, we first need to understand the principle of gesture scaling. Gesture zooming is implemented by listening to touch events. When the user slides the screen with two fingers, the page will follow the sliding movement of the fingers.
