pc端和移动端两套样式在vue中的切换

完成了一套网页,其中既有pc端也有移动端。

那么怎样使其在不同的浏览器宽度下,自行适配页面呢?

首先,一套移动端页面,一套pc端页面。

为每套移动端页面增加例如mobile类名,为pc端页面增加如pc类名。

或是为页面最外层元素增加mobile类名或pc类名。

然后在公共样式中增加媒体查询,如下所示:

这样,一旦检测到浏览器宽度大于1080px,那么类名为mobile的移动端页面消失,而类名为pc的pc端页面呈现。

说到这里,你应该大致明白,在vue项目中,页面是由两个组件组成:一个时适配pc端的页面,而另一个则是适配移动端的页面。如下图:(这是路由中的总页面)

插播一条路由截图:

具体到某个展示页面的两个组件:

homepagePc是页面的类名即为pc

homeageM是页面的类名即为mobile

M端页面,需要增加媒体查询,以适应不用屏幕大小的移动端

@media only screen and (min-width: 320px) and (max-width: 374px) {

    html {

        font-size: 13.6533px !important;

    }

}

@media only screen and (min-width: 375px) and (max-width: 413px) {

    html {

        font-size: 16px !important;

    }

}

@media only screen and (min-width: 414px) and (max-width: 429px) {

    html {
    
        font-size: 17.664px !important;

    }

}

@media only screen and (min-width: 430px) and (max-width: 765px) {

    html {

        font-size: 18.3467px !important;

    }

}

@media only screen and (min-width: 768px) {

    html {

        font-size: 32.768px !important;

    }

}

 

### Vue PC项目适配移动端方案 #### 一、使用 `postcss-pxtorem` `amfe-flexible` 为了更好地处理不同屏幕尺寸下的样式问题,在Vue项目中可以引入`postcss-pxtorem``amfe-flexible`来实现单位从`px`到`rem`的转换。这有助于保持布局的一致性灵活性[^2]。 安装依赖: ```bash npm install postcss-pxtorem amfe-flexible --save-dev ``` 配置`postcss.config.js`文件,设置根字体大小以及哪些文件夹内的CSS需要被转换: ```javascript module.exports = { plugins: [ require('postcss-pxtorem')({ rootValue: 16, // 设计稿宽度/10 或者其他值 propList: ['*'] }) ] } ``` 在入口HTML文件中加入`<script>`标签加载`flexible.js`: ```html <script src="./path/to/flexible.js"></script> ``` #### 二、调整视口元数据 对于已经存在的PC项目来说,如果发现页面无法正常缩小显示,则可能是由于`meta viewport`标签的存在方式不当所引起的。建议保留必要的属性并适当修改其参数以适应移动设备的需求。例如,将原有的<meta>标签改为如下形式可帮助浏览器正确渲染网页内容[^3]: ```html <meta name="viewport" content="width=device-width, initial-scale=1"> ``` #### 三、构建独立的移动端路由体系 当业务逻辑差异较大时,考虑为移动端单独编一套路由规则也是一种有效的策略。这样可以根据访问终的不同加载相应的组件服务,从而提供更佳用户体验[^4]。 创建两个不同的路由配置文件分别用于PC移动端,并通过检测User-Agent等方式决定启动哪一路由实例: ```javascript // pcRoutes.js import Home from './views/Home.vue'; export default [ { path: '/', component: Home }, ... ]; // mobileRoutes.js import MobileHome from './views/MobileHome.vue'; export default [ { path: '/', component: MobileHome }, ... ]; ``` 最后根据环境变量或请求头中的信息动态切换使用的路由器对象: ```javascript const isMobile = /Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent); app.use(VueRouter, new VueRouter(isMobile ? mobileRoutes : pcRoutes)); ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值