利用flexible.js和VSCode插件cssrem进行可伸缩布局方案

简介: 利用flexible.js和VSCode插件cssrem进行可伸缩布局方案

1. flexible.js

flexible原理就是根据不同的屏幕宽度动态的设置网页中html根节点的font-size,然后咱们将所有的px用rem来代替,这样就实现了不同大小的屏幕都适应相同的样式了。

GItHub地址
在这里插入图片描述
flexible默认配置是将屏幕宽度分成10等份,如果需要自己手动修改可直接复制index.js的代码到本地使用,如果不需要修改,可直接使用index.min.js里已经压缩过的代码。

这里我需要将屏幕宽度改成等分24等份,所以使用index.js里未压缩的代码,方便自己修改:

(function flexible(window, document) {
    var docEl = document.documentElement
    var dpr = window.devicePixelRatio || 1

    // adjust body font size
    function setBodyFontSize() {
        if (document.body) {
            document.body.style.fontSize = (12 * dpr) + 'px'
        } else {
            document.addEventListener('DOMContentLoaded', setBodyFontSize)
        }
    }
    setBodyFontSize();

    // set 1rem = viewWidth / 10 
    function setRemUnit() {
        var rem = docEl.clientWidth / 10
        docEl.style.fontSize = rem + 'px'
    }

    setRemUnit()

    // reset rem unit on page resize
    window.addEventListener('resize', setRemUnit)
    window.addEventListener('pageshow', function(e) {
        if (e.persisted) {
            setRemUnit()
        }
    })

    // detect 0.5px supports
    if (dpr >= 2) {
        var fakeBody = document.createElement('body')
        var testElement = document.createElement('div')
        testElement.style.border = '.5px solid transparent'
        fakeBody.appendChild(testElement)
        docEl.appendChild(fakeBody)
        if (testElement.offsetHeight === 1) {
            docEl.classList.add('hairlines')
        }
        docEl.removeChild(fakeBody)
    }
}(window, document))

这个代码就是仓库里index.js的代码,大家也可以直接复制这个代码去项目使用,针对我的需求将屏幕划分成24等份,只需修改:

    // set 1rem = viewWidth / 24 此时把屏幕平均划分为24等分
    function setRemUnit() {
        var rem = docEl.clientWidth / 24
        docEl.style.fontSize = rem + 'px'
    }

然后去项目里引用该js文件即可:

  <script src="js路径"></script>

然后配合cssrem使用

2. cssrem

下载aaVScode插件:
在这里插入图片描述
在这里插入图片描述

进入插件扩展设置进行配置:
在这里插入图片描述
这里我将基准改为了80,对于80是怎么来的,是因为我是针对1920px的设计稿进行开发,并且将flexible手动修改了24等份,1920/24=80,所以这里我设置为了80,具体设置可根据自己的需求以及flexible的配置进行修改。

然后在项目里使用时,该插件就会自动提示将px单位转为rem单位:
在这里插入图片描述
这里是说在我的配置下200px等于2.5rem,然后我选择它使用rem单位即可
==注意:不使用rem单位是无法进行可伸缩适配的==

这样下来项目就可以适配不同大小的屏幕了!

3. 案例展示:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>echarts数据可视化</title>
    <script src="./js/echarts.min.js"></script>
    <!-- 利用flexible.js适配屏幕:flexible.js配置中我们将屏幕划分成了24等分 -->
    <script src="js/flexible.js"></script>
    <style>
        /* 屏幕宽度小于1024px后固定单位 因为项目配置是将屏幕划分成24等分,所以是1024/24=42.66 */
        
        @media screen and (max-width:1024px) {
            html {
                font-size: 42.66px !important;
            }
        }
        /* 屏幕宽度大于1920px后固定单位 因为项目配置是将屏幕划分成24等分,所以是1920/24=80 */
        
        @media screen and (min-width:1920px) {
            html {
                font-size: 80px !important;
            }
        }
        
        .box {
            width: 2.5rem;
            height: 2.5rem;
            background-color: pink;
        }
    </style>
</head>

<body>
    <div class="box"></div>
</body>

</html>
相关文章
|
24天前
|
JavaScript 前端开发
javascript开发的简单的弹幕插件
这是一个原生javascript开发的简单的弹幕插件,具有美观、易用,占用的资源较低等特点,可以给弹幕设置内容、颜色、头像、链接地址等属性,鼠标悬停等,简单实用,欢迎下载!
39 5
|
1月前
|
自然语言处理 JavaScript 开发者
通义灵码插件:VSCode 的智能编程助手
通义灵码插件:VSCode 的智能编程助手
254 3
|
1月前
|
前端开发 JavaScript 编译器
2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
【10月更文挑战第11天】2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
71 0
2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
|
2月前
|
自然语言处理 JavaScript 前端开发
一文梳理JavaScript中常见的七大继承方案
该文章系统地概述了JavaScript中七种常见的继承模式,包括原型链继承、构造函数继承、组合继承、原型式继承、寄生式继承、寄生组合继承等,并探讨了每种模式的实现方式及其优缺点。
一文梳理JavaScript中常见的七大继承方案
|
24天前
|
JavaScript 定位技术
jQuery鹰眼视图小地图定位预览插件minimap.js
这是一个jQuery小地图定位预览视图,默认左侧是页面主要内容,minimap.js的好处就是在它的右侧形成一个快速定位通道,产生一个缩小版的页面,即预览效果,可以点击并快速定位到页面的某个位置。简单实用,欢迎下载!
30 0
|
1月前
|
存储 JSON JavaScript
Vue.js开发中基于localStorage与sessionStorage的本地存储利器:Vue-ls插件使用详解
Vue.js开发中基于localStorage与sessionStorage的本地存储利器:Vue-ls插件使用详解
48 0
|
3月前
|
前端开发 Go
vscode10大常用插件
本文介绍了前端开发中常用的工具及VSCode必备插件。推荐使用VSCode作为入门工具,并介绍了WebStorm和HBuilder等其他选项。VSCode插件包括:Open-In-Browser、live-server、Beautify、Code Runner、Image Preview、Path Intellisense、Turbo Console Log、css-auto-prefix、Bracket Pair Colorizer 和 Auto Rename Tag,这些插件能够显著提升开发效率和代码质量。此外,还提供了录制Gif图的工具GifCam。
140 5
vscode10大常用插件
|
1月前
|
JavaScript 前端开发 容器
js之弹性布局使用方法
js之弹性布局使用方法
30 0
|
1月前
|
JavaScript 前端开发
原生js常见报错及其处理方案
原生js常见报错及其处理方案
20 0
|
2月前
|
人工智能 C++ 开发者
verilog vscode 与AI 插件
【9月更文挑战第11天】在Verilog开发中,使用Visual Studio Code(VS Code)结合AI插件能显著提升效率。VS Code提供强大的编辑功能,如语法高亮、自动补全和代码格式化;便捷的调试功能,支持多种调试器;以及丰富的插件生态。AI插件则可自动生成代码、优化现有代码、检测并修复错误,还能自动生成文档。常用插件包括Verilog AI Assistant和Verilog Language Server,可根据需求选择合适的工具组合,提高开发效率和代码质量。
126 2
下一篇
无影云桌面