Vue realizes screen adaptation of large screen pages

Vue realizes screen adaptation of large screen pages

This article shares the specific code of Vue to achieve screen adaptation of large-screen pages for your reference. The specific content is as follows

1. Set the size of the large screen design to 1920*1080 in the configuration file

//appConfig.js
export default{
    screen:{
        width:1920,
        height:1080,
        scale:20
    }//Large screen design width and height}

2. Define resetScreenSize.js

import appConfig from '../config/base'
 
export function pageResize(callback) {
    let init = () => {
        console.log(window.innerHeight + "," + window.innerWidth);    
        let _el = document.getElementById('app');
       
        let hScale = window.innerHeight / appConfig.screen.height;
        let wScale = window.innerWidth / appConfig.screen.width;
        let pageH = window.innerHeight;
        let pageW = window.innerWidth;
       
        let isWider = (window.innerWidth / window.innerHeight) >= (appConfig.screen.width / appConfig.screen.height);
        console.log(isWider);
        if (isWider) {
                _el.style.height = window.innerHeight+'px'; // '100%';
                _el.style.width = pageH * appConfig.screen.width / appConfig.screen.height + 'px';
                _el.style.top='0px';
                _el.style.left=(window.innerWidth -pageH * appConfig.screen.width / appConfig.screen.height)*0.5+'px';
                console.log(_el.style.width + "," + _el.style.height)
        }
        else {
                _el.style.width = window.innerWidth+'px'; // '100%';
                _el.style.height = pageW * appConfig.screen.height / appConfig.screen.width + 'px';
                _el.style.top = 0.5*(window.innerHeight-pageW * appConfig.screen.height / appConfig.screen.width)+'px';
                _el.style.left='0px';
                console.log(_el.style.height);
                console.log(_el.style.top);
        }
        document.documentElement.style.fontSize = (_el.clientWidth / appConfig.screen.scale) + 'px';
 
      
    }    
    var resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
    window.addEventListener(resizeEvt, init, false);
    document.documentElement.addEventListener('DOMContentLoaded', init, false);
    init()
}

3 Usage

main.js import

import appConfig from './config/base.js';
Vue.prototype.appConfig=appConfig;
app.Vue import {pageResize} from './utils/resetScreenSize' in the mounted function
 
export default {
  name: 'App',
  data(){
    return {
       
    }
  },
  mounted(){
    pageResize();
    console.log('pageResize');
  }
}

Style lang="stylus" in the component

 .mc{
        display :flex;
        flex-direction :column;
        align-content :center;
        justify-content :center;  
        display: flex;
        flex: 1 1 auto;
        flex-direction: column;
        padding:(15/96)rem;
    }
 
    .leftC{
       width: (410/96)rem;
    }
 
    .centerC{
       width: (1060/96)rem;
    }
 
    .rightC{
       width: (450/96)rem;
    }

96 is derived from 1920/20 in the configuration file, so there is no need to perform various conversions.

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • VUE develops the background management page steps of the distributed medical registration system
  • Example steps for VUE to build a distributed medical registration system backend management page
  • How to implement page jump in Vue project
  • VUE develops hospital settings page steps for distributed medical registration system

<<:  Detailed explanation of the persistence implementation principle of transactions in MySQL

>>:  HTML validate HTML validation

Recommend

Summary of the data storage structure of the nginx http module

Starting from this section, we will explain the i...

MySQL green decompression version installation and configuration steps

Steps: 1. Install MySQL database 1. Download the ...

HTML basics HTML structure

What is an HTML file? HTML stands for Hyper Text M...

Detailed explanation of creating stored procedures and functions in mysql

Table of contents 1. Stored Procedure 1.1. Basic ...

Multiple ways to calculate age by birthday in MySQL

I didn't use MySQL very often before, and I w...

Solution to the failure of docker windows10 shared directory mounting

cause When executing the docker script, an error ...

How to use xshell to connect to Linux in VMware (2 methods)

【Foreword】 Recently I want to stress test ITOO...

Analysis of MySQL crash recovery based on Redo Log and Undo Log

Table of contents MySQL crash recovery process 1....

File upload via HTML5 on mobile

Most of the time, plug-ins are used to upload fil...

Solve the installation problem of mysql8.0.19 winx64 version

MySQL is an open source, small relational databas...

Design of image preview in content webpage

<br />I have written two articles before, &q...