102012
 

上个月参加了w3ctech的技术交流会,小米科技展示了很多有css3的优化技巧。而现在正要介绍的这个技巧就是小米的工程师为为大家介绍的。在此感谢w3ctech和小米科技。

一般情况下,在布局页面的时候一下这种效果图都会使用一个小的背景图平铺实现。但是如果使用标准浏览器和CSS3,那么可以很容易的使用linear-gradient这个属性模拟出以下效果图

效果图:

核心CSS代码如下:兼容(Firefox和chrome)

在线demo:

请使用Firefox或chrome查看

http://www.ffasp.com/plugs/linear-gradient/gewen.htm

 

  发表于 上午 9:49
092012
 

译者注:本系列文章由石川创作,李松峰翻译,w3ctech.com首发,图灵社区转载。 “OOP与jQuery”是“解码jQuery”系列中的一个子系列,主要讨论 jQuery 的内部构成及相关的OOP(Object Oriented Programming,面向对象编程)概念。 在这篇文章中,我们会讨论工厂设计模式,也是jQuery核心中使用的一种设计模式。 1.创建对象 “四人帮”的名著Design Patterns: Elements of Reusable Object-Oriented Software(《设计模式》,http://en.wikipedia.org/wiki/Design_Patterns )把设计模式分为三类: 创建模式:创建对象的各种方式; 结构模式:组合各种对象以实现新的功能; 行为模式:对象之间互操作的方式。 工厂模式属于创建模式,顾名思义,工厂就是创建对象的。 我们先来看一看创建对象的最常见模式。好,以下代码创建了一个包含几个方法的对象。

如果想通过taskManager创建一个新的任务对象,而且是基于不同的类型分别调用update和read方法,那可以这样做:

  可是,如果有10种不同的任务,这样做就太麻烦了。因此,就产生了工厂方法模式。 2.工厂方法模式 为了简化创建对象的工作,可以在taskManager中创建一个工厂方法:

有了这个方法,就可以像下面这样创建对象了:

  3.jQuery中的工厂方法 在jQuery的core.js中,就有一个类似的创建对象的工厂方法:

  使用这种方法的原因很简单,jQuery不知道用户会传入什么样的选择符,或许是标签名,如$(‘p’);ID,如 $(‘#main’) ,或者类,如 $(‘.item’)。因此,这个方法适合创建类似但事先又不知其具体类型的对象。 这里有一篇文章,叫Essential JavaScript Design Patterns For Beginners, Volume 1(http://addyosmani.com/resources/essentialjsdesignpatterns/book/),讨论了什么时候该用工厂模式,什么时候不该用工厂模式。

  发表于 上午 5:49
062012
 
阮一峰:Javascript编程风格

Douglas Crockford是Javascript权威,Json格式就是他的发明。 去年11月他有一个演讲(Youtube),谈到了好的Javascript编程风格是什么。 我非常推荐这个演讲,它不仅有助于学习Javascript,而且能让你心情舒畅,因为Crockford讲得很幽默,时不时让听众会心一笑。 下面,我根据这个演讲和Crockford编写的代码规范,总结一下”Javascript编程风格”。 所谓”编程风格”(programming style),指的是编写代码的样式规则。不同的程序员,往往有不同的编程风格。 有人说,编译器的规范叫做”语法规则”(grammar),这是程序员必须遵守的;而编译器忽略的部分,就叫”编程风格”(programming style),这是程序员可以自由选择的。这种说法不完全正确,程序员固然可以自由选择编程风格,但是好的编程风格有助于写出质量更高、错误更少、更易于维护的程序。 所以,有一点应该明确,“编程风格”的选择不应该基于个人爱好、熟悉程度、打字工作量等因素,而要考虑如何尽量使代码清晰易读、减少出错。你选择的,不是你喜欢的风格,而是一种能够清晰表达你的意图的风格。这一点,对于Javascript这种语法自由度很高、设计不完全成熟的语言尤其重要。 一、大括号的位置 绝大多数的编程语言,都用大括号({})表示区块(block)。起首的大括号的位置,有许多不同的写法。 最流行的有两种。一种是起首的大括号另起一行:   block { … } 另一种是起首的大括号跟在关键字的后面:   block { … } 一般来说,这两种写法都可以接受。但是,Javascript要使用后一种,因为Javascript会自动添加句末的分号,导致一些难以察觉的错误。   return { key:value; }; 上面的代码的原意,是要返回一个对象,但实际上返回的是undefined,因为Javascript自动在return语句后面添加了分号。为了避免这一类错误,需要写成下面这样:   return { key : value; }; 因此,   规则1:表示区块起首的大括号,不要另起一行。 二、 圆括号 圆括号(parentheses)在Javascript中有两种作用,一种表示调用函数,另一种表示不同的值的组合(grouping)。我们可以用空格,区分这两种不同的括号。   规则2:调用函数的时候,函数名与左括号之间没有空格。   规则3:函数名与参数序列之间,没有空格。   规则4:所有其他语法元素与左括号之间,都有一个空格。 按照上面的规则,下面的写法都是不规范的:   foo (bar) return(a+b); if(a === 0) {…} function foo (b) {…} function(x) [...]

  发表于 下午 3:16