位置: 编程技术 - 正文

js中flexible.js实现淘宝弹性布局方案(flexable.js)

编辑:rootadmin

推荐整理分享js中flexible.js实现淘宝弹性布局方案(flexable.js),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js的fixed,flexible.js使用,js的floor,flexable.js,flexible.js vue,js flexible,flexible.js原理,js flexible,内容如对您有帮助,希望把文章链接给更多的朋友!

本文的内容就是介绍淘宝弹性布局方案lib-flexible实践,分享给大家供大家参考,具体内容如下

1. 页面需求

这是要做的页面效果(不要对设计置评,这不是开发人员决定的):

这是尺寸标注图(*):

然后美工在*的设计稿之上,按我的要求提供以下素材的切图:

包括两个下载按钮的背景图片,logo,底部梯形的渐变背景和body部分的mobile 背景图。注意这些图片都是在*的设计稿里面切出来的,所以尺寸都是设计稿里的原始尺寸,比如android.png:

考虑到retina显示屏的问题,结合下图的适配思路:

我认为解决retina屏问题的可行方案是:

1)在devicePixelRatio<=2时,图片统一使用设计稿的切图

2)在devicePixelRatio>=2时,图片统一使用*1.5=,也就是所谓@3x设计稿的切图。

我把美工给我的在*的设计稿下的切图都放在img/@2x 这个文件夹下:

然后让她帮忙把的设计稿矢量放大1.5倍,再按照同样的切图要求为我提供@3x的切图,并放在了img/@3x 这个文件夹下:

js中flexible.js实现淘宝弹性布局方案(flexable.js)

@3x下的图片理论上尺寸应该等于@2x下的图片*1.5,不过我的切的没有这么完美。

有了前面的需求介绍和素材准备,下一步就是该引入核心的js文件,编写css样式了。

2. 引入flexible.js

这一步其实非常简单,只要把flexible.js的内容复制出来,在本地新建一个flexible.js的文件,打开粘贴进去就可以了,我把这个文件放在了js/lib下面:

接着在html页面里面,尽可能早的引入这个js文件(为了让适配的效果更快):

注:使用lib-flexible,通常不要写:

交给flexible.js自动处理。

然后在chrome的模拟器里面,选择iphone6,应该就能看到html的font-size已经被设置为font-size: px了:

3. 编写CSS基本要求:

1)除font-size外,其它大小都根据标注稿的尺寸,转换成rem单位的值,转换方法为:标注稿尺寸 / 标注稿基准字体大小;

2)标注稿基准字体大小 = 标注稿宽度 / ,如标注稿宽为,标注稿基准字体大小为;标注稿宽为,标注稿基准字体大小为;(所以淘宝这个方案是可以在任意设计稿尺寸下使用的)

3)如果需要设置font-size,可跟据html的data-dpr属性来处理,类似下面的写法:

以安卓下载按钮的样式为例,说明这种用法。android.png的尺寸为:*,所以css这么写:

由于用了less,事先定义了一个变量来保存标注稿基准字体大小:

@font-size-base: ;所以px2rem的转换变得非常容易,如上所示。less编译之后,会将正确的rem值计算出来:

到此,lib-flexible的基本实践就结束了,不过还有一个问题,就是retina屏的问题,到现在都还没提到@3x下图的那些切图怎么办,其实很简单,借助html元素的data-dpr属性,可以轻松实现另一种媒介查询,以便在devicePixelRatio>=2的时候启用@3x下的图片,还是以安卓下载按钮的样式为例,写法是:

这下就OK了,原先还不知道data-dpr有什么作用,现在看看,作用还是挺大的。

注:

1) 由于使用了grunt构建,所以需要先安装node ,git,再通过npm安装grunt 和bower 2)考虑到将来可能要做全屏滚动的效果,所以这页面一开始就是用fullpage.js来做的,通过bower引入了jquery跟fullpage.js的库 3) 模块化用到了requirejs 4)运行grunt default完成构建,再运行grunt server启动静态服务器预览。

标签: flexable.js

本文链接地址:https://www.jiuchutong.com/biancheng/385537.html 转载请保留说明!

上一篇:正则表达式优化JSON字符串的技巧(正则化实现)

下一篇:谈谈我对JavaScript原型和闭包系列理解(随手笔记8)(谈谈我对美国的印象)

  • 企业所得税的征收对象是什么
  • 普通发票忘记开数量和单价可以用吗
  • 发票专用章和财务章区别
  • 去年滞纳金没入营业外今天怎么账务处理
  • 收入入账会计分录
  • 开出已验旧的发票怎么办
  • 记账软件收费吗
  • 发票后面附清单明细能导出吗
  • 进项税加计抵减生产性服务
  • 固定资产评估增值的账务处理
  • 事业单位收个人部分社保怎么入账
  • 去年销售怎么算
  • 佣金可以直接转到个人账户吗
  • 一般纳税人如何零申报
  • 国外汇款 用什么理由
  • 月底结转应交税费怎么弄
  • 免税的销售额要怎么填入报表
  • 所得税税负率是多少
  • 筹建期如何界定
  • 税收征管法实施条例
  • 长期股权投资账面价值和公允价值不一致
  • 用友t3怎么删除损益结转凭证
  • 施工现场应建立什么
  • 怎么把过期银行卡的钱取出来
  • 加速折旧的会计分录
  • 季度利润
  • Win10 20H1/20H2 KB5001391补丁今日发布(内附下载)
  • 年度企业所得税计算方法
  • 麦克米伦anki
  • PHP:zip_close()的用法_Zip函数
  • 小程序开发一个多少钱啊
  • framework3.5怎么打开
  • js如何转换为数值型
  • php怎么调用图片
  • 固定资产的销售怎么做账
  • 关税计入纳税总额么
  • 销售产品收到现金的会计分录
  • 资产负债表里长期股权投资是什么意思
  • 有收入就要结转成本吗为什么
  • 坏账损失的会计分录小企业会计准则
  • 小规模纳税人每月不超过10万
  • 应收账款资金占用费怎么算
  • 红字发票销项税额账务处理
  • 代收代缴的水电费怎么开票
  • 公司向股东个人借款怎么做账
  • 一次性补缴一年社保
  • 研发阶段的产品质检要参与
  • 填制费用报销单怎么填写
  • 申报工资总额除以在职人员人数
  • 公司收到劳务发票交个税吗
  • 会计核算采用什么形式
  • 固定资产清理包括什么会计科目
  • 新建企业需要什么手续
  • 除MSSQL数据库text字段中恶意脚本的删方法
  • mac中怎么给表情添加文字
  • u盘安装vista
  • 电脑待机状态下载会继续吗
  • winxp安卓
  • linux 详解
  • 借助竹子赞美人物气节的诗句有哪些
  • win7关闭混合睡眠
  • mac系统不能升级怎么办
  • win10应用商店是灰的
  • win7远程桌面连接命令
  • WIN10系统怎么分屏
  • win7任务管理器怎么调回原来样子
  • linux html编辑器
  • linux012
  • linux内存耗尽怎么解决
  • cocos2djs
  • javascript内置对象应用团购
  • 电脑安装node
  • unity简单项目
  • unity3d官方教程
  • 如何用js实现一个简单的计算器
  • js鼠标滚轮缩放
  • 消费税由消费者承担吗
  • 国家税务总局广州市税务局
  • 四川省地方税务局公告2018年第1号
  • 养老机构范畴
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设