效果图:

就是把header的背景图实现以上效果,模糊效果,在遮盖罩下方,图片和商家头像图片一样。

我一开始的想法是直接给header设置背景图片,但是图片是商家头像,数据是通过后端获取的,那么css可以使用js的数据吗?网上查了一下,答案是可以的。

我们知道CSS里是可以控制某些HTML元素的属性的,譬如background-image等等,而在URL里添加Javascript:alert()等等类似的代码就可以用来执行代码。

我用的CSS代码如下:

<style type="text/css">
body{height:200px;
background:url(javascript:alert("test!"));
}

将这段代码随意插入到任何页面中都会执行其中的JS代码.

显然这开启了针对很多对于CSS具备自由编辑功能的很多BSP(BLOG服务提供商)的攻击思路,而对CSS入手的攻击目前作防范的很少.

从另一角度来看,设计系统可以在JS设计时考虑利用CSS进行包含和引用.这是很好的一个从JS控制CSS到CSS控制JS的一个反作用.

而深发出一个看法,具体待验证:凡是可以放URL的地方,均可以试试放javascript,可能就能成功!

关键字:css调用javascript 代码  css调用js代码

CSS中expression使用简介

定义 
  IE5及其以后版本支持在CSS中使用expression,用来把CSS属性和Javas cript表达式关联起来,这里的CSS属性可以是元素固有的属性,也可以是自定义属性。就是说CSS属性后面可以是一段Javas cript表达式,CSS属性的值等于Javas cript表达式计算的结果。 在表达式中可以直接引用元素自身的属性和方法,也可以使用其他浏览器对象。这个表达式就好像是在这个元素的一个成员函数中一样。

  给元素固有属性赋值

  例如,你可以依照浏览器的大小来安置一个元素的位置。

#myDiv {position: absolute;
width: 100px;
height: 100px;
left: expression(document.body.offsetWidth - 110 + "px");
top: expression(document.body.offsetHeight - 110 + "px");
background: red;
}

 给元素自定义属性赋值

  例如,消除页面上的链接虚线框。 通常的做法是:

<a href="link1.htm" onfocus="this.blur()">link1</a>
<a href="link2.htm" onfocus="this.blur()">link2</a>
<a href="link3.htm" onfocus="this.blur()">link3</a> 

粗看或许还体现不出采用expression的优势,但如果你的页面上有几十甚至上百个链接,这时的你难道还会机械式地Ctrl+C,Ctrl+V么,何况两者一比较,哪个产生的冗余代码更多呢?

  采用expression的做法如下:

<style type="text/css">
a {star : expression(οnfοcus=this.blur)}
</style>
<a href="link1.htm">link1</a>
<a href="link2.htm">link2</a>
<a href="link3.htm">link3</a> 

!!!注意 
不是非常需要,一般不建议使用expression,因为expression对浏览器资源要求比较高。 能不用则不用,会导致性能问题。

还有就是在IE 和 firefox 下执行正常,但是在chrome 中可能会失常

如果我这里用javascript,好像不是很符合逻辑,如果用expression,可能获取到的seller.avatar不能被解析为一个url,而且性能低,所以,我还是使用教程的方法吧。

就是在header这个父元素里建立一个直接子元素background,然后通过绝对定位以及z-index:-1达到效果

<div class="background">
<img :src="seller.avatar" width="100%" height="100%">
</div>        //父元素是header

.header
position:relative
overflow: hidden
color:#fff
background:rgba(7, 17, 27, 0.5)
.background
position: absolute
top: 0
left: 0
width:100%
height:100%
z-index:-1
filter:blur(10px)

filter是css3的新属性,定义了元素(通常是<img>)的可视效果(例如:模糊与饱和度)。

具体用法:http://www.runoob.com/cssref/css3-pr-filter.html

饿了么webapp之header的背景相关推荐

  1. 饿了吗app都是用html写的,Vue2.0仿饿了么webapp单页面应用详细步骤

    这篇文章主要为大家详细介绍了Vue2.0仿饿了么webapp单页面应用详细步骤,具有一定的参考价值,可以用来参考一下. 感兴趣的小伙伴,下面一起跟随512笔记的小编两巴掌来看看吧! 部分截图 [图片暂 ...

  2. vue2.0仿饿了么webAPP项目

    # webapp vue2.x仿饿了么app项目总结 项目地址:https://github.com/harrietjia/vue2-webapp.git 如果觉得有帮助,希望可以在右上角给我个sta ...

  3. Vue2.0饿了吗的实践-header组件的实践

    header组件的实现图: header组件的代码: html: <template> <div class="header"> <div class ...

  4. Vue2.x开发饿了么项目(header部分)

    header组件开发 数据之间的传递 App.vue 引入组件,App.vue 中注册组件,使用组件时 要记得传入seller参数 通过父组件向子组件传递数据 在父组件中需要将sellerO作为数据导 ...

  5. 基于vue的仿饿了么webapp

    1.项目介绍 此项目为外卖App核心的商家模块的SPA SPA是为构建WebApp设计的路由控制和视图转换框架 包括商品.评论.商家介绍.购物车等多个子模块 使用 Vuejs全家桶 + ES6 + W ...

  6. 本地运行github上的vue2.0仿饿了么webapp项目

    在vue刚刚开始流行的时候,大多数人学习大概都见到过这样的一个项目吧,可以作为学习此框架的一个模板了 github源码地址:https://github.com/RegToss/Vue-SPA 课程教 ...

  7. vue高仿饿了么项目学习笔记之二:头部header组件的实现

    1. Vue-resource应用 在父组件APP.vue的钩子函数created使用vue-resource来ajax请求/api/seller,将数据赋值给vue实例的seller对象,并传值给子 ...

  8. Header背景处理方案

    自己在私下项目练习时,遇到的一种header部分背景开发方案,前端小伙伴可以用在我们自己code的项目里面. 应用场景,针对于不同事物具有唯一的图像标识(例如,用户的头像,书籍的封面等). 我们在设计 ...

  9. 基于Vue移动音乐webapp跨域获取QQ音乐歌单接口

    最近看了一个vue移动音乐webapp教程,老师是一个来自滴滴公司的名为黄轶的前端大神,之前学习了他的一个基于vue仿饿了么webapp的初级教程,感觉非常好,十分适合新手,但是那个教程的数据都是前端 ...

最新文章

  1. android shape 按钮背景_flutter好用的轮子推荐十三-flutter可展开选项的浮动按钮
  2. 五大IT巨头 成立专利联盟
  3. 实验吧— Crypto Write up(一)
  4. mysql排序空放后面_python对mysql数据库的增删改查
  5. oracle 监控 视图,【转】oracle几个常用的监控视图
  6. 【bzoj1708】[USACO2007 Oct]Money奶牛的硬币 背包dp
  7. arraylist扩容是创建新数组吗 java_Java ArrayList扩容问题实例详解
  8. Linux打印介绍【转贴】
  9. linux nona怎么用_Linux nano编辑器命令常用方法
  10. JavaScript DOM操作总结
  11. TCP 理论概述与 Java 编码入门
  12. 米勒拉宾算法(素性测试)
  13. java计算机毕业设计小区失物招领网站源程序+mysql+系统+lw文档+远程调试
  14. 神经网络学习笔记(一) RBF径向基函数神经网络
  15. 使用Fiddler5和雷电模拟器4.0.83的抓包配置
  16. 深入理解 Comparable 接口和 Comparator 接口以及Arrays.sort()
  17. 第七次全国人口普查登记今日零时启动 六大释疑都在这
  18. 【BZOJ3407】[Usaco2009 Oct]Bessie's Weight Problem 贝茜的体重问题【01背包】
  19. java 获取两个List 中 不同对象
  20. 电子元件-压敏电阻与气体放电管

热门文章

  1. Linux下MySQL报Table 'xxx' doesn't exist错误解决方法
  2. 探索基于计算机的数字音频工作站
  3. GNSS接收机的工作原理
  4. VUE3+ThreeJs实现3D全景场景,可自由旋转视角
  5. Bash - 趣味Shell
  6. vue-cli3.0引入高德3d动画效果方法一:
  7. 创业之初需要的是人而不是钱
  8. letax插入eps图片后生成不了pdf
  9. Python 输出10个不重复的英文字母 随机输入一个字符串,把最左边的10个不重复的英文字母(不区分大小写)挑选出来。 如没有10个英文字母,显示信息“找不到10个不重复的英文字母”
  10. 求助,哪位大佬能帮助我解决一下这个问题,感激不尽