vue2PC端和移动端适配

之前ui 给pc端的设计稿是 1920* 1080 ,并没有提过要写移动端网站,所以之前一直做的是pc端。

1,安装 flexible和 postcss-px2rem(命令行安装)
npm install lib-flexible --save

npm install postcss-px2rem --save
vue.confit.js的文件中:


   css:{
        loaderOptions:{
            css:{},
            sass:{
                sassOptions:{
                    outputStyle:'expanded'//解决有时不想转换px值写了/*no*/之后打包后又转换成rem的问题
                }
            },
            postcss:{
                plugins:[
                    require('postcss-px2rem')({
                        remUnit:192
                    }),//换算的基数
                ]
            }
        }
    }

 在main.js里引入   import 'lib-flexible'   ,如果是多人开发需将 lib-flexible文件下的flexible.js复制出来放在utils文件夹下再改动里面的配置,在main.js里引入  import './utils/flexible'      //移动端PC端适配

在node_modules 找到 lib-flexible文件下的flexible.js,然后找到refreshRem函数,将其改为:

 

那么pc端的适配就好了

后来又在这的基础上要加入移动端的适配,并且UI给的移动端设计图是750,额鹅鹅鹅,而pc端的是1920,在网上查了,好像没找到 怎么同事解决给1920的设计稿和750的设计稿,最终自己摸索了会,将lib-flexible文件下的flexible.js,然后找到refreshRem函数改为:

function refreshRem(){

console.log('将根据已有的meta标签来设置缩放比例',win)

var width = docEl.getBoundingClientRect().width;

if (width / dpr > 540) {

width = width * dpr;

}

 

let flag = win.navigator.userAgent.match(

/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i

);

if(flag === null) {

console.log("pc端");

var rem = width / 10;

 

}else {

console.log("移动端");

var rem = (width / 10)*2.56; // 移动端的2.56 是 我用 192 /75 = 2.56 然后移动端的尺寸就可以1:1 进行

 

}

docEl.style.fontSize = rem + 'px';

flexible.rem = win.rem = rem;

}

《----------------------------------------------------------》

然后 首页:

<template>

<div class="home" >

<div v-if="type" class="homePC">

<div class="headerNav" v-if="type">

<div class="logo">

<img src="@/assets/images/home/logo.png" alt="">

</div>

<ul class="titleNav">

<router-link :to=item.routerName tag="li" v-for="(item,index) in navList" :key="index" class="title">{{item.name}}</router-link>

</ul>

</div>

<div>

<router-view></router-view>

</div>

<div :class="$route.path==='/developmentCenter' || $route.path==='/developmentCloud'?'footer footDevelopment':$route.path==='/index'?'footer footIndex':'footer'" >

<div><a href="#" target="_blank" class="beian">陕ICP备*****号-1</a></div>

<div class="titleFoot">陕西****科技有限公司</div>

</div>

</div>

<div v-if="!type" class="homeMobile">

<div class="mobileHeaderNav">

<div class="mobileNav">

<img src="@/assets/mobileImages/home/icoNav.png" alt="" @click="mobileNavClick">

</div>

<div class="mobileLogo">

<img src="@/assets/mobileImages/home/logo.png" alt="">

</div>

<div class="mobileNavContent" v-show="navHalfMobile" @click="navLiClick">

<ul class="mobileUl" >

<router-link tag="li" v-for="(item,i) in navListMobile" :key="i" :to=item.routerName @click="navLiClick">

<div class="mobileIclPadding">

<img :src="item.ico" alt="" :class="'mobileImg'+i">

</div>

<div class="mobileTitle">{{item.title}}</div>

</router-link>

</ul>

</div>

</div>

<div>

<router-view></router-view>

</div>

<!-- class="mbileFooter" -->

<div :class="$route.path==='/index' || $route.path==='/mobileDevelopment' || $route.path==='/mobileDevelopmentCloud'?'mbileFooter mbileFooterBack':'mbileFooter'">

<a href="#" target="_blank" class="beianMobile">陕ICP备*****号-1</a>

<div class="companyMobile">陕西****科技有限公司</div>

</div>

 

</div>

</div>

 

</template>

<script>

export default {

name: 'Home',

data () {

return {

// value1: 0,

navList:[

{

name:'首页',

routerName:'index'

},

{

name:'研发中心',

routerName:'developmentCenter'

},

{

name:'国科学院',

routerName:'academySciences'

},

{

name:'产品中心',

routerName:'productCenter'

},

{

name:'开发云',

routerName:'developmentCloud'

},

{

name:'专家团队',

routerName:'expertTeam'

},

{

name:'联系我们',

routerName:'contactUs'

}

],

navListMobileRouter:[

{

name:'首页',

routerName:'index'

},

{

name:'研发中心',

routerName:'mobileDevelopment'

},

{

name:'国科学院',

routerName:'academySciences'

},

{

name:'产品中心',

routerName:'productCenter'

},

{

name:'开发云',

routerName:'developmentCloud'

},

{

name:'专家团队',

routerName:'expertTeam'

},

{

name:'联系我们',

routerName:'contactUs'

}

],

navListMobile:[

{

ico:require('@/assets/mobileImages/home/homeIco.png'),

title:'首页',

routerName:'index'

},{

ico:require('@/assets/mobileImages/home/developmentIco.png'),

title:'研发中心',

routerName:'mobileDevelopment'

}, {

ico:require('@/assets/mobileImages/home/academyIco.png'),

title:'国科学院',

routerName:'mobileAcademySciencest'

}, {

ico:require('@/assets/mobileImages/home/developmentIco.png'),

title:'产品中心',

routerName:'mobileProductCenter'

}, {

ico:require('@/assets/mobileImages/home/cloudIco.png'),

title:'开发云',

routerName:'mobileDevelopmentCloud'

}, {

ico:require('@/assets/mobileImages/home/experIco.png'),

title:'专家团队',

routerName:'mobileexpertTeam'

}, {

ico:require('@/assets/mobileImages/home/contactIco.png'),

title:'联系我们',

routerName:'contactUs'

}

],

type:true,

navHalfMobile:false

}

},

created() {

console.log(navigator.userAgent)

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

);

console.log('66666666666666666',flag);

if(flag === null) {

console.log("pc端");

this.type = true

 

}else {

console.log("移动端");

this.type = false

 

}

},

methods:{

mobileNavClick() {

this.navHalfMobile = true

},

navLiClick() {

setTimeout(() => {

this.navHalfMobile = false

},500)

 

}

}

}

</script>

由于首页路面涉及到重定向,所以首页的pc端和移动端我写在了一个页面,剩下的页面可以和pc端分开写

 

### px转换为rem
、、、
px后面添加/*no*/,就不会转化为rem。一般border需要。

px后面添加/*px*/,会根据dpr的不同生成三套代码。一般字体需要。

.box {
  font-size:14px;/*px*/
  border: 1px;/*no*/
}
、、、

 

posted @ 2022-12-04 14:25  小闫的姑娘  阅读(1582)  评论(1编辑  收藏  举报