专注于WEB前端开发, 追求更好的用户体验, 更好的开发体验 [长沙前端QQ群:234746733]

开发

  • 关于Creative Commons(创作共用)

    / 分类: 开发 / No Comments

    创作共用中国大陆版 (CC China) 2.5协议今天在北京中国人民大学举办的 "简体中文版创作共用协议发布会暨数字化时代的知识产权与创作共用国际会议" 上正式发布.

    劳伦斯·莱斯格在发布会上的演讲创作共用组织的创始人斯坦福大学法律系教授劳伦斯·莱斯格 (Lawrence Lessig) 以及创作共用组织的多名成员出席了会议, 并介绍了著作权在数字时代下的问题以及创作共用协议的发展历史.

    在创作共用中国大陆项目组正式发布创作共用中国大陆许可协议的当天, iMagine有限公司在香港发布了第一张采用创作共用中国大陆许可协议的CD唱片《PatPet》. 该唱片采用创作共用 "署名-非商业性使用-禁止演绎 2.5 中国大陆" (cc-nc-nd 2.5 China)协议.

    CC China 项目负责人王春燕教授创作共用中国大陆小组的项目负责人, 中国人民大学法学院王春燕副教授在会上说: "在中国大陆引进创作共用许可协议极其重要. 在西方严格的版权保护方法和中国传统的全社会分享知识创造成果的观念之间,创作共用许可协议的观念和方法为中国社会提供了一种合理并切实可行的中间道路. "

    她同时说: "在中国大陆引进创作共用组织的许可协议体系将能进一步促进创造性活动的发展并丰富创造性作品, 同时提高中国人民与世界上其他社会和文化进行有效沟通的能力. "

    创作共用 (Creative Commons) 组织简称为CC, 是劳伦斯·莱斯格在2001年创办的一个非营利机构. 此组织的主要宗旨是增加创意作品的流通可及性, 作为其他人据以创作及共享的基础, 并寻找适当的法律以确保上述理念.

    根据创作共用组织的要求, 由于不同司法管辖区的法律体制和制作权法不同, 因此在不同司法管辖区需要根据原始协议进行本地化一切和当地的法律要求. 由此, 创作共用中国小组最初在CNBlog.org的毛向辉发起下 (开始的名称叫做 "创作共享" ) , 通过民间合作完成了1.0版的翻译和本地化工作. 在2005年以后, 该项目交与中国人民大学负责2.5协议的本地化工作.

    创作共用协议允许作者选择不同的授权条款, 指定四种条件并作出6种不同的组合来为作品授权:

    CC的标志姓名标示 (by)
    非商业性 (nc)
    禁止改作 (nd)
    相同方式分享 (sa)

                                                                                                                                          2006-03-30

    ----------------------------------------

    以下内容来自http://www.creativecommons.cn/

    从“保留所有权利”到“保留部分权利”

    我们通常熟知的唯一一种版权声明方式“保留所有权利”(All Rights Reserved)已经被滥用到任何人都可能触犯版权法律,人们只知道在自己的任何大小的作品(甚至本身也是在别人的成果基础上的再创造)都无以复加地声明为“保留所有权利”。这样的结果一方面导致原创者应有的权利得不到尊重,另一方面是很多优秀的作品(无论是艺术作品、文学作品、个人思想还是其他数字作品等)都无法得到最大价值利用或最广泛传播。虽然在很多国家的版权法律默认地赋予原创者很多权利,但是越来越多的人们开始意识到自己并非需要保留所有权利。相反他们更愿意选择“保留部分权利”(Some Rights Reserved)或“不保留权利”(No Rights Reserved)。

    十一种授权选择

    “创作共用”协议机制提供了由4个最常见的授权选择的组合方式,任何作品都可以通过选择这性地组合声明自己的作品授权,实际上可以有11种常见的组合方式。这些组合方式构成了从“松”到“紧”的授权限制,给作品的创造者更加灵活便利的选择。为网络上的数字作品提供了新的“护身符”。

    CC China 2.5版权生成器

    CC China官方网站

  • Class与ID的区别

    / 分类: 开发 / No Comments

    一个Class是用来根据用户定义的标准对一个或多个元素进行定义的。打个比较恰当的比方就是剧本:一个Class可以定义剧本中每个人物的故事线,你可以通过CSS,Javascript等来使用这个类。因此你可以在一个页面上使用class="Frodo" ,class="Gandalf", class="Aragorn"来区分不同的故事线。还有一点非常重要的是你可以在一个文档中使用任意次数的Class。 
       
    至于 ID,通常用于定义页面上一个仅出现一次的标记。在对页面排版进行结构化布局时(比如说通常一个页面都是由一个页眉,一个报头< masthead>,一个内容区域和一个页脚等组成),一般使用ID比较理想,因为一个ID在一个文档中只能被使用一次。而这些元素在同一页面中很少会出现大于一次的情况。 
       
    归纳成一句话就是:Class可以反复使用而ID在一个页面中仅能被使用一次。有可能在很大部分浏览器中反复使用同一个ID不会出现问题,但在标准上这绝对是错误的使用,而且很可能导致某些浏览器的现实问题。(刚才在Dreamweaver中试了一下,确实,并没有出错) 
       
    在实际应用的时候,Class可能对文字的排版等比较有用,而ID则对宏观布局和设计放置各种元素较有用。 

  • CSS的十八般技巧

    / 分类: 开发 / No Comments

    一.使用css缩写
    使用缩写可以帮助减少你CSS文件的大小,更加容易阅读。css缩写的主要规则如下:

    颜色
    16进制的色彩值,如果每两位的值相同,可以缩写一半,例如:
    #000000可以缩写为#000;#336699可以缩写为#369;

    盒尺寸
    通常有下面四种书写方法:

    property:value1; 表示所有边都是一个值value1;

    property:value1 value2; 表示top和bottom的值是value1,right和left的值是value2

    property:value1 value2 value3; 表示top的值是value1,right和left的值是value2,bottom的值是value3

    property:value1 value2 value3 value4; 四个值依次表示top,right,bottom,left


    方便的记忆方法是顺时针,上右下左。具体应用在margin和padding的例子如下:
    margin:1em 0 2em 0.5em;


    边框(border)
    边框的属性如下:

    border-width:1px;

    border-style:solid;

    border-color:#000;

    可以缩写为一句:border:1px solid #000;

    语法是border:width style color;

    背景(Backgrounds)
    背景的属性如下:

    background-color:#f00;

    background-image:url(background.gif);

    background-repeat:no-repeat;

    background-attachment:fixed;

    background-position:0 0;

    可以缩写为一句:background:#f00 url(background.gif) no-repeat fixed 0 0;

    语法是background:color image repeat attachment position;

    你可以省略其中一个或多个属性值,如果省略,该属性值将用浏览器默认值,默认值为:

    color: transparent

    image: none

    repeat: repeat

    attachment: scroll

    position: 0% 0%

    字体(fonts)
    字体的属性如下:

    font-style:italic;

    font-variant:small-caps;

    font-weight:bold;

    font-size:1em;

    line-height:140%;

    font-family:”Lucida Grande”,sans-serif;

    可以缩写为一句:font:italic small-caps bold 1em/140% “Lucida Grande”,sans-serif;

    注意,如果你缩写字体定义,至少要定义font-size和font-family两个值。

    列表(lists)
    取消默认的圆点和序号可以这样写list-style:none;,

    list的属性如下:

    list-style-type:square;

    list-style-position:inside;

    list-style-image:url(image.gif);

    可以缩写为一句:list-style:square inside url(image.gif);

    二.明确定义单位,除非值为0
    忘记定义尺寸的单位是CSS新手普遍的错误。在HTML中你可以只写width=”100″,但是在CSS中,你必须给一个准确的单位,比如:width:100px width:100em。只有两个例外情况可以不定义单位:行高和0值。除此以外,其他值都必须紧跟单位,注意,不要在数值和单位之间加空格。

    三.区分大小写
    当在XHTML中使用CSS,CSS里定义的元素名称是区分大小写的。为了避免这种错误,我建议所有的定义名称都采用小写。

    class和id的值在HTML和XHTML中也是区分大小写的,如果你一定要大小写混合写,请仔细确认你在CSS的定义和XHTML里的标签是一致的。

    四.取消class和id前的元素限定
    当你写给一个元素定义class或者id,你可以省略前面的元素限定,因为ID在一个页面里是唯一的,而clas s可以在页面中多次使用。你限定某个元素毫无意义。例如:

    div#content { /* declarations */ }
    fieldset.details { /* declarations */ }

    可以写成

    #content { /* declarations */ }
    .details { /* declarations */ }

    这样可以节省一些字节。

    五.默认值
    通常padding的默认值为0,background-color的默认值是transparent。但是在不同的浏览器默认值可能不同。如果怕有冲突,可以在样式表一开始就先定义所有元素的margin和padding值都为0,象这样:

    * {
    margin:0;
    padding:0;
    }

    六.不需要重复定义可继承的值
    CSS中,子元素自动继承父元素的属性值,象颜色、字体等,已经在父元素中定义过的,在子元素中可以直接继承,不需要重复定义。但是要注意,浏览器可能用一些默认值覆盖你的定义。

    七.最近优先原则
    如果对同一个元素的定义有多种,以最接近(最小一级)的定义为最优先,例如有这么一段代码

    Update: Lorem ipsum dolor set

    在CSS文件中,你已经定义了元素p,又定义了一个class”update”

    p {
    margin:1em 0;
    font-size:1em;
    color:#333;
    }
    .update {
    font-weight:bold;
    color:#600;
    }

    这两个定义中,class=”update”将被使用,因为class比p更近。你可以查阅W3C的《Calculating a selector’s specificity》了解更多。

    八.多重class定义
    一个标签可以同时定义多个class。例如:我们先定义两个样式,第一个样式背景为#666;第二个样式有10 px的边框。

    .one{width:200px;background:#666;}
    .two{border:10px solid #F00;}

    在页面代码中,我们可以这样调用


    这样最终的显示效果是这个div既有#666的背景,也有10px的边框。是的,这样做是可以的,你可以尝试一下。

    九.使用子选择器(descendant selectors)
    CSS初学者不知道使用子选择器是影响他们效率的原因之一。子选择器可以帮助你节约大量的class定义。我们来看下面这段代码:

    <div id="subnav">
    <ul>
    <li class="subnavitem"> <a href="#" class="subnavitem">Item 1</a></li>>
    <li class="subnavitemselected"> <a href="#" class="subnavitemselected"> Item 1</a> </li>
    <li class="subnavitem"> <a href="#" class="subnavitem"> Item 1</a> </li>
    </ul>
    </div>

    这段代码的CSS定义是:

    div#subnav ul { /* Some styling */ }
    div#subnav ul li.subnavitem { /* Some styling */ }
    div#subnav ul li.subnavitem a.subnavitem { /* Some styling */ }
    div#subnav ul li.subnavitemselected { /* Some styling */ }
    div#subnav ul li.subnavitemselected a.subnavitemselected { /* Some styling */ }

    你可以用下面的方法替代上面的代码

    <ul id="subnav">
    <li> <a href="#"> Item 1</a> </li>
    <li class="sel"> <a href="#"> Item 1</a> </li>
    <li> <a href="#"> Item 1</a> </li>
    </ul>

    样式定义是:

    #subnav { /* Some styling */ }
    #subnav li { /* Some styling */ }
    #subnav a { /* Some styling */ }
    #subnav .sel { /* Some styling */ }
    #subnav .sel a { /* Some styling */ }

    用子选择器可以使你的代码和CSS更加简洁、更加容易阅读。

    十.不需要给背景图片路径加引号
    为了节省字节,我建议不要给背景图片路径加引号,因为引号不是必须的。例如:

    background:url("images/***.gif") #333;

    可以写为

    background:url(images/***.gif) #333;

    如果你加了引号,反而会引起一些浏览器的错误。

    十一.组选择器(Group selectors)
    当一些元素类型、class或者id都有共同的一些属性,你就可以使用组选择器来避免多次的重复定义。这可以节省不少字节。

    例如:定义所有标题的字体、颜色和margin,你可以这样写:

    h1,h2,h3,h4,h5,h6 {
    font-family:”Lucida Grande”,Lucida,Arial,Helvetica,sans-serif;
    color:#333;
    margin:1em 0;
    }

    如果在使用时,有个别元素需要定义独立样式,你可以再加上新的定义,可以覆盖老的定义,例如:

    h1 { font-size:2em; }
    h2 { font-size:1.6em; }

    十二.用正确的顺序指定链接的样式
    当你用CSS来定义链接的多个状态样式时,要注意它们书写的顺序,正确的顺序是::link :visited :hover :active。抽取第一个字母是”LVHA”,你可以记忆成”LoVe HAte”(喜欢讨厌)。为什么这么定义,可以参考Eric Meyer的《Link Specificity》。

    如果你的用户需要用键盘来控制,需要知道当前链接的焦点,你还可以定义:focus属性。:focus属性的效果也取决与你书写的位置,如果你希望聚焦元素显示:hover效果,你就把:focus写在:hover前面;如果你希望聚焦效果替代:hover效果,你就把:focus放在:hover后面。

    十三.清除浮动
    一个非常常见的CSS问题,定位使用浮动的时候,下面的层被浮动的层所覆盖,或者层里嵌套的子层超出了外层的范围。

    通常的解决办法是在浮动层后面添加一个额外元素,例如一个div或者一个br,并且定义它的样式为clear: both。这个办法有一点牵强,幸运的是还有一个好办法可以解决,参看这篇文章《How To Clear Floats Without Structural Markup》

    上面2种方法可以很好解决浮动超出的问题,但是如果当你真的需要对层或者层里的对象进行clear的时候怎么办?一种简单的方法就是用overflow属性,这个方法最初的发表在《Simple Clearing of Floats》,又在《Clearance》和《Super simple clearing floats》中被广泛讨论。

    上面那一种clear方法更适合你,要看具体的情况,这里不再展开论述。另外关于float的应用,一些优秀的文章已经说得很清楚,推荐你阅读:《Floatutorial》、 《Containing Floats》和《Float Layouts》

    十四.横向居中(centering)
    这是一个简单的技巧,但是值得再说一遍,因为我看见太多的新手问题都是问这个:CSS如何横向居中?你需要定义元素的宽,并且定义横向的margin,如果你的布局包含在一个层(容器)中,就象这样:

    你可以这样定义使它横向居中:

    #wrap {
    width:760px; /* 修改为你的层的宽度 */
    margin:0 auto;
    }

    但是IE5/Win不能正确显示这个定义,我们采用一个非常有用的技巧来解决:用text-align属性。就象这样:

    body {
    text-align:center;
    }
    #wrap {
    width:760px; /* 修改为你的层的宽度 */
    margin:0 auto;
    text-align:left;
    }

    第一个body的text-align:center; 规则定义IE5/Win中body的所有元素居中(其他浏览器只是将文字居中) ,第二个text-align:left;是将#warp中的文字居左。

    十五.导入(Import)和隐藏CSS
    因为老版本浏览器不支持CSS,一个通常的做法是使用@import技巧来把CSS隐藏起来。例如:

    @import url("main.css");

    然而,这个方法对IE4不起作用,这让我很是头疼了一阵子。后来我用这样的写法:

    @import "main.css";

    这样就可以在IE4中也隐藏CSS了,呵呵,还节省了5个字节呢。想了解@import语法的详细说明,可以看这里《centricle’s css filter chart》

    十六.针对IE的优化
    有些时候,你需要对IE浏览器的bug定义一些特别的规则,这里有太多的CSS技巧(hacks),我只使用其中的两种方法,不管 microsoft.com/china/homepage/ms.htm" target="_blank">微软在即将发布的IE7 beta版里是否更好的支持CSS,这两种方法都是最安全的。

    1.注释的方法
    (a)在IE中隐藏一个CSS定义,你可以使用子选择器(child selector):
    html>body p {
    /* 定义内容 */
    }
    (b)下面这个写法只有IE浏览器可以理解(对其他浏览器都隐藏)
    * html p {
    /* declarations */
    }
    (c)还有些时候,你希望IE/Win有效而IE/Mac隐藏,你可以使用”反斜线”技巧:
    /* \*/
    * html p {
    declarations
    }
    /* */
    2.条件注释(conditional comments)的方法
    另外一种方法,我认为比CSS Hacks更加经得起考验就是采用 microsoft.com/china/homepage/ms.htm" target="_blank">微软的私有属性条件注释(conditional comments)。用这个方法你可以给IE单独定义一些样式,而不影响主样式表的定义。就象这样:

    <!–[if IE]>
    <link rel="stylesheet" type="text/css" href="ie.css" />
    <![endif]–>
    十七.调试技巧:层有多大?
    当调试CSS发生错误,你就要象排版工人,逐行分析CSS代码。我通常在出问题的层上定义一个背景颜色,这样就能很明显看到层占据多大空间。有些人建议用border,一般情况也是可以的,但问题是,有时候border 会增加元素的尺寸,border-top和boeder-bottom会破坏纵向margin的值,所以使用background更加安全些。

    另外一个经常出问题的属性是outline。outline看起来象boeder,但不会影响元素的尺寸或者位置。只有少数浏览器支持outline属性,我所知道的只有Safari、OmniWeb、和Opera。

    十八.CSS代码书写样式
    在写CSS代码的时候,对于缩进、断行、空格,每个人有每个人的书写习惯。在经过不断实践后,我决定采用下面这样的书写样式:

    selector1,
    selector2 {
    property:value;
    }

    当使用联合定义时,我通常将每个选择器单独写一行,这样方便在CSS文件中找到它们。在最后一个选择器和大括号{之间加一个空格,每个定义也单独写一行,分号直接在属性值后,不要加空格。

    我习惯在每个属性值后面都加分号,虽然规则上允许最后一个属性值后面可以不写分号,但是如果你要加新样式时容易忘记补上分号而产生错误,所以还是都加比较好。
    最后,关闭的大括号}单独写一行。
    空格和换行有助与阅读。

  • 删除域名的规律 和 域名状态解释

    / 分类: 开发 / No Comments

    域名过期后1~45天内
    将处于注册商保留状态
    whois英文状态:REGISTRAR-HOLD

    域名过期后第二阶段
    注册商保留期结束之后
    域名将进入30天赎回期
    whois英文状态:REDEMPTION-PERIOD

    域名过期后第三阶段
    赎回期结束之后域名将
    进入6天的删除未决期
    6天期满后域名删除
    whois英文状态:PENDING-Delete

    whois英文状态:REGISTRAR-LOCK是域名锁定状态,过期后防止被转移注册商。 1:比如域名aaa.com到期时间为2003年03月01日;
    2:从2003年03月02日开始,域名的ns将会被系统自动删除,域名无法解析,但我公司会继续保留该域名30天,用户可以在这30天的期限内续费;
    3:如果在2所述的30天期限内没有续费,即从2003年03月31日开始,域名将变成RedemptionPeriod状态,该状态将会保持30天,在此期间该域名不会掉下来,但是除了restore命令以外的所有命令对此域名无效;
    4:域名在RedemptionPeriod状态下可以restore回来,但每restore一次需要支付费用;
    5:如果域名在RedemptionPeriod状态下的30天没有restore,从2003.04.29开始域名变成PendingDelete状态(5天),2003年05月04日该域名将会删除。


    VeriSign于2003年1月在其Registry Whois (.COM和.NET)中加了3个字段:

    Status、Creation Date、Expiration Date

    其中 Status 目前发现有8种状态,分别是:

    1、ACTIVE:活动状态。由Registry设置;该域名可以由Registrar更改;可以续费;至少被指派一个DNS。

    2、REGISTRY-LOCK:注册局锁定。由注册局设置;该域名不可以由注册商更改、删除;必须由注册局解除此状态才可以由注册商更改域名信息;域名可以续费;如果域名被指派至少一个DNS则可以包含在(域名根服务器)的区域中(可以正常使用)。

    3、REGISTRY-HOLD:注册局保留。由注册局设置;该域名不可以由注册商更改、删除;必须由注册局解除此状态才可以由注册商更改域名信息;域名可以续费;该域名不包括在(域名根服务器)的区域中(不能正常使用)。

    4、REGISTRAR-LOCK:注册商锁定。由该域名的原始注册商设置;该域名不可以被更改或删除;必须由注册商解除此状态才可以更改域名信息;该域名可以续费。该域名包含在(域名根服务器)的区域中(可以正常使用)。

    5、REGISTRAR-HOLD:注册商保留。由该域名的原始注册商设置;该域名不可以被更改或删除;必须由注册商解除此状态才可以更改域名信息;该域名可以续费。该域名不包括在(域名根服务器)的区域中(不能正常使用)。

    6、REDEMPTIONPERIOD:宽限期。当注册商向注册局提出删除域名请求后,由注册局将域名设置称此状态,不过,条件是该域名已经注册了5天以上(如果该域名注册时间不足5天,则立即删除);该域名不包括在(域名根服务器)的区域中(不能正常使用);该域名不可以被更改或清除,只可以被恢复;任何其他注册商提出对此域名的更改或其他请求都将被拒绝;该状态最多保持30天。

    7、PENDINGRESTORE:恢复未决。当注册商提出将处于REDEMPTIONPERIOD的域名恢复请求后,由注册局设置;该域名包含在(域名根服务器)的区域中(可以正常使用);注册商提出的更改或任何其他请求都将被拒绝;在7天之内,有注册商向注册局提供必需的恢复文件,如果注册商在7天之内提供了这些文件,该域名将被置为ACTIVE状态,否则,该域名将重新返回到REDEMPTIONPERIOD状态。

    8、PENDINGDelete:删除未决。如果一个域名在被设置成REDEMPTIONPERIOD状态期间内,注册商没有提出恢复请求,那么,域名将被置于PENDINGDelete状态,注册商对此域名的任何请求都将被拒绝;5天之后清除。