[demo]自定义响应式网页(利用css3媒体查询和window.matchMedia实现)
2018-11-16 18:43
591 查看
版权声明:本文作者“Tom哥”,版权归作者所有,欢迎转载,但请务必在明显位置注明作者和原文链接,否则保留追究法律责任的权利。 https://blog.csdn.net/tom_wong666/article/details/84143978
需求:
自定义响应式网页,需要针对不同的屏幕尺寸做不同的处理。
分析:
1,样式处理,必须是css3媒体查询,简单有效;
2,行为和结构的处理,我们选用window.matchMedia函数处理;
验证(vue框架中做的验证,代码如下):
1,新建matchMedia文件夹,里面新建index.vue文件,写好如下代码,建立一个自定义响应式网页组件:
[code]<template> <div class='media' @click="getTips"> window.matchMedia查询结果提示 </div> </template> <script> export default{ methods:{ //点击时验证js提示色是否和如下css设置的一致 getTips(){ if(window.matchMedia('screen and (min-width:992px)').matches){ alert("大屏 红色") }else if(window.matchMedia('screen and (min-width:768px) and ( max-width: 992px)').matches){ alert("中屏 绿色") }else if(window.matchMedia('screen and (max-width: 768px)').matches){ alert("小屏 蓝色") } }, }, } </script> <style lang="less" scoped> @media screen and (min-width:992px){ .media{ color:red; } } @media screen and (min-width:768px) and (max-width: 992px){ .media{ color:green; } } @media screen and (max-width: 768px){ .media{ color:blue; } } </style>
2,在router文件夹的index.js文件内引入上一步建立的vue文件,并为其设置访问路径
[code]//引入定义好的响应式组件 import matchMedia from '@/page/matchMedia/index'
[code] { //为响应式组件设置访问路径 path: '/matchMedia', name: 'matchMedia', component: matchMedia }
3,npm run dev项目跑起来,在地址栏增加后缀/matchMedia访问该组件,切换浏览器尺寸,并在不同尺寸下点击验证。
备注:
此设置已验证OK,需要看源码的同学,可以克隆如下项目查看:
demo的github地址:https://github.com/tom-wong666/xiaoa.git
博文通览提示:
Tom哥的博客博文分类和索引页面地址:https://www.geek-share.com/detail/2753347056.html
阅读更多相关文章推荐
- 响应式网页必备——media媒体查询
- 用百分比布局和媒体查询@media来实现响应式网页的编码
- 利用CSS3媒体查询实现更换样式表
- CSS3 利用@media screen实现网页布局的自适应
- 利用@media screen实现网页布局的自适应,@media screen and
- 利用TagSupport创建自定义标签实现网页左侧菜单
- 利用@media screen实现网页布局的自适应
- CSS3 Media Queries 实现响应式demo
- 利用@media screen实现网页布局的自适应
- 有关CSS3中的media媒体查询
- GridView利用分页存储过程实现真正的自定义分页查询
- 利用@media screen实现网页布局的自适应
- css 利用媒体查询进行响应式设计
- css3媒体查询实现网站响应式布局
- 利用@media screen实现网页布局的自适应
- 【media-queries】媒体查询,为了响应式设计而生
- 利用@media screen实现网页布局的自适应
- CSS3 Media Query 响应式媒体查询
- 利用@media screen实现网页布局的自适应
- CSS3响应式 Web 设计(三)@media 查询