`
shameant
  • 浏览: 59089 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Css之expression应用

    博客分类:
  • Ajax
阅读更多

IE 支持CSS实在实在是太烂了,当大佬当惯了,我行我素,不按照W3C的规章办事,结果就苦了我们这帮开发的。

 

基础他的缺陷,这里我们拿他的小伎俩来弥补一下过错。

 

SA:

加入我们要使用一个DIV在一个BODY下居中(horizantal)显示。

FIREFOX下很简单,just use :

 

<style>
    div {margin:0 auto;
}
</style>
 

ok.It is fine!

但是,IE 下显示不正常,这里我们借用一下IE Trick:expression.

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

 

So:

<style>
div{
margin-left:expression(document.body.offsetWidth/2-document.div.width/2)

}
</style>

 OK .

然后,只需要在前面定义的Margin:0 auto后加一个!important.起目的是为了不让Ie 去识别这个属性,这也是为了兼容浏览器使用的一种HACK技术

 

以下内容 转摘自网络:

More:

 

给元素自定义属性赋值

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

<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(onfocus=this.blur)}
</style>
<a href="link1.htm">link1</a>
<a href="link2.htm">link2</a>
<a href="link3.htm">link3</a>

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

<style type="text/css">
input
{star : expression(onmouseover=this.style.backgroundColor="#FF0000";
onmouseout=this.style.backgroundColor="#FFFFFF")}
</style>
<style type="text/css">
input {star : expression(onmouseover=this.style.backgroundColor="#FF0000";
onmouseout=this.style.backgroundColor="#FFFFFF")}
</style>
<input type="text">
<input type="text">
<input type="text">

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

<style type="text/css">
input {star : expression(onmouseover=function()
{this.style.backgroundColor="#FF0000"},
onmouseout=function(){this.style.backgroundColor="#FFFFFF"}) }
</style>
<input type="text">
<input type="text">
<input type="text">

  注意

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

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

    问题说明: 用过CSS样式我们就知道, 可以定义一批对象的class属性来指定同一个样式来统一界面. 但如何统一同类型的对象的事件? 比如:界面有无数个 <img src="**.jpg"> 如何实现鼠标经过此图片, 图片的src变成是**_over.jpg?
 
 
解决方法: 使用css的expression方法,
具体实现要看看.css的写法:
 
/*替换图片CSS*/
#imgScript {   /*这里使用对象ID来通配样式, 也可以定义一个css函数*/
 star:expression(
    onmouseover = function()
    {
        /*替换图片*/
        if(this.hover != null){
          this.name = this.src;
          this.src = this.src.replace('.jpg', '_over.jpg');
          this.HasChg = 1;
       }
   },
   onmouseout = function()
  { 
       /*还原本来的图片*/
     if(this.HasChg != null){
        this.src = this.name;
        this.HasChg = null;
    }
 }
)

}/*end imgScript*/

分享到:
评论

相关推荐

    css expression使用概述及其优缺点介绍

    CSS Expression的使用主要是通过`expression`属性,可以直接在CSS中定义。例如,下面的代码片段展示了如何创建一个返回顶部按钮,并将其保持在屏幕底部: ```css .toTop { top: expression(eval(document....

    CSS expression 隔行换色效果

    '#9FB7F6':'#B6C8F8')` 是一个CSS expression的例子,它应用于`UL.myul1 LI`选择器。`this.sourceIndex%2`计算当前元素在DOM树中的索引位置除以2的余数。如果余数为0,那么背景颜色将设为`#9FB7F6`;否则,背景颜色...

    CSS expression判断表达式设置input样式

    【CSS expression】是一种过时的CSS技术,它允许开发者基于某些条件动态地改变元素的样式。这个特性在Internet Explorer浏览器的早期版本(主要是IE5.5和IE6)中被支持,但并未被其他主流浏览器如Firefox、Chrome、...

    css3-frog-expression.zip

    在数字化的今天,网页设计的视觉表现力越来越受到重视,而CSS3作为现代网页设计的核心技术之一,无疑为设计师提供了无尽的创意可能。当我们谈论“css3-frog-expression.zip”时,我们可以看到一个关于CSS3在创建动态...

    JSF+JS+CSS的一个应用

    在"JSF+JS+CSS的一个简单应用"中,我们可以理解这个项目可能包含以下几个方面: 1. **JSF页面结构**:项目可能包含多个JSF页面,每个页面由UI组件组成,如按钮、输入框、表格等。这些组件可以通过JSF的EL...

    第十四节 IE中利用CSS触发XSS-01

    "IE中利用CSS触发XSS-01" 在IE浏览器中,CSS可以用来触发XSS攻击。本节课程将介绍如何使用CSS来触发XSS...* CSS表达式的概念和应用 * 注释在CSS中的作用 * XSS攻击的概念和防御方法 * IE浏览器中的安全问题和解决方法

    CSS中使用expression完美设置页面最小宽度(兼容ie)

    例如,可以使用JavaScript检测浏览器类型和版本,然后针对性地应用`expression`,或者利用CSS3的媒体查询来定义不同屏幕尺寸下的样式。 总之,`expression`是IE浏览器中解决页面最小宽度问题的一种方法,但因其非...

    Thingworx Expression&Eventsrouter Widget

    在Thingworx物联网平台上,Expression&Eventsrouter Widget是两个非常重要的组件,它们为开发者提供了强大的功能,用于数据处理和事件管理。这篇文档将详细介绍这两个组件的高级用法,并且对于初次接触Thingworx平台...

    Expression

    5. **编程与Web字体**:在网页设计中,可以使用@font-face CSS规则引入网络字体,使访问者能够在浏览器中看到“Expression”字体,前提是服务器提供了相应的字体文件。 6. **兼容性**:不同的操作系统和应用程序对...

    CssStyle.txt

    在这段CSS规则中,使用了`css:expression()`语法,这是一个非标准但常被使用的功能,主要用于在JavaScript中动态地计算或更改CSS属性。具体来说,在这个例子中,当鼠标悬停在`&lt;tr&gt;`元素上时(`onmouseover`事件),...

    css判断界面大小

    本文将详细介绍如何通过CSS媒体查询实现界面大小的判断,并据此调整样式,使之更适合移动设备等小屏幕显示。 ### 一、CSS媒体查询简介 #### 1.1 基本概念 媒体查询是一种CSS3功能,它允许开发者根据不同的设备特性...

    CSS_information.rar_c# css_c#css_c#的css_正则表达式

    C#中的Server Control可以通过设置属性来应用CSS样式,或者在代码中动态生成CSS,以实现动态样式调整。理解C#与CSS的交互,能帮助开发者更好地创建响应式和交互性强的网页。 CSS2参考:CSS2是CSS的第二个主要版本,...

    Expression studio2 key

    Expression Blend 2是一款功能强大的用户界面设计工具,主要用于创建基于XAML的应用程序和内容。它支持交互式原型设计、动画创建等功能,并且与Visual Studio等其他开发工具集成良好。 - **序列号**: TJ2R3-WHW22-B...

    常用的东西表达式 js css 之类

    在IT行业中,尤其是在Web开发领域,正则表达式(Regular Expression)、JavaScript(JS)和CSS是不可或缺的基础知识。这些技术广泛应用于数据验证、页面交互以及样式设计等方面,为网页提供了丰富的功能和美观的视觉...

    css expression实现的图片自动缩放

    媒体查询允许开发者基于设备特性(如视口宽度)应用不同的CSS样式,这样当窗口尺寸变化时,可以自动调整图片的尺寸。例如: ```css @media (max-width: 600px) { .Image { width: 100%; height: auto; } } ``` ...

    用CSS防iframe型挂马

    1. **CSS Expression**: CSS表达式(expression)是IE特有的一个功能,允许在CSS样式中嵌入JavaScript代码。虽然这个特性在现代浏览器中已被废弃,但在某些情况下仍然可以用于防御特定类型的攻击。 - **语法**: `...

    让IE6也识别CSS3-圆角效果应用border-radius

    6. **多背景图层**:利用CSS3的多重背景功能,可以将一个带有圆角的图片作为背景之一,然后在上面覆盖元素内容。这种方法在IE6下可能需要额外的图片或JavaScript支持。 7. **使用条件注释**:针对IE6专门写一段包含...

    microsoft expression web

    2. **CSS样式表**:深入探讨CSS的使用,包括选择器、属性、值,以及如何创建和应用CSS样式,实现页面的布局和美化。 3. **响应式设计**:介绍如何利用Expression Web创建适应不同屏幕尺寸的网页,包括媒体查询的...

    可爱的CSS3卡通表情旋转动画特效

    例如,如果表情被包含在一个具有"class='cartoon-expression'"的`div`元素中,那么上面的CSS规则就会生效。 在`index.html`文件中,HTML结构可能会类似这样: ```html &lt;!DOCTYPE html&gt; 可爱的CSS3卡通表情...

Global site tag (gtag.js) - Google Analytics