javascript

位置:IT落伍者 >> javascript >> 浏览文章

expression将JS、Css结合起来


发布日期:2019年01月08日
 
expression将JS、Css结合起来
IE及其以后版本支持在CSS中使用expression用来把CSS属性和Javas cript表达式关联起来这里的CSS属性可以是元素固有的属性也可以是自定义属性就是说CSS属性后面可以是一段Javas cript表达式CSS属性的值等于Javas cript表达式计算的结果在表达式中可以直接引用元素自身的属性和方法也可以使用其他浏览器对象这个表达式就好像是在这个元素的一个成员函数中一样

给元素固有属性赋值

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

#myDiv {

position: absolute;

width: px;

height: px;

left: expression(documentbodyoffsetWidth + px);

top: expression(documentbodyoffsetHeight + px);

background: red;

}

给元素自定义属性赋值

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

<a onfocus=thisblur()>link</a>

<a onfocus=thisblur()>link</a>

<a onfocus=thisblur()>link</a>

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

采用expression的做法如下

<style type=text/css>

a {star : expression(onfocus=thisblur)}

</style>

<a >link</a>

<a >link</a>

<a >link</a>

说明里面的star就是自己任意定义的属性你可以随自己喜好另外定义接着包含在expression()里的语句就是JS脚本在自定义属性与expression之间可别忘了还有一个引号因为实质还是CSS所以放在style标签内而非s cript内OK这样就很容易地用一句话实现了页面中的链接虚线框的消除不过你先别得意如果触发的特效是CSS的属性变化那么出来的结果会跟你的本意有差别例如你想随鼠标的移进移出而改变页面中的文本框颜色更改你可能想当然的会认为应该写为

<style type=text/css>

input

{star : expression(onmouseover=thisstylebackgroundColor=#FF;

onmouseout=thisstylebackgroundColor=#FFFFFF)}

</style>

<style type=text/css>

input {star : expression(onmouseover=thisstylebackgroundColor=#FF;

onmouseout=thisstylebackgroundColor=#FFFFFF)}

</style>

<input type=text>

<input type=text>

<input type=text>

可结果却是出现脚本出错正确的写法应该把CSS样式的定义写进函数内如下所示

<style type=text/css>

input {star : expression(onmouseover=function()

{thisstylebackgroundColor=#FF}

onmouseout=function(){thisstylebackgroundColor=#FFFFFF}) }

</style>

<input type=text>

<input type=text>

<input type=text>

注意

不是非常需要一般不建议使用expression因为expression对浏览器资源要求比较高

实例利用css里expression来实现界面对象的批量控制

问题说明: 用过CSS样式我们就知道 可以定义一批对象的class属性来指定同一个样式来统一界面 但如何统一同类型的对象的事件? 比如:界面有无数个 <img src=**jpg> 如何实现鼠标经过此图片 图片的src变成是**_overjpg?

解决方法: 使用css的expression方法

具体实现要看看css的写法:

/*替换图片CSS*/

#imgScript { /*这里使用对象ID来通配样式 也可以定义一个css函数*/

star:expression(

onmouseover = function()

{

/*替换图片*/

if(thishover != null){

thisname = thissrc;

thissrc = thissrcreplace(jpg _overjpg);

thisHasChg = ;

}

}

onmouseout = function()

{

/*还原本来的图片*/

if(thisHasChg != null){

thissrc = thisname;

thisHasChg = null;

}

}

)

}/*end imgScript*/

上一篇:JS的IE和Firefox兼容性汇编

下一篇:JS if语句的几种优化