编码原则:

1. 不太归罪于Js,一切根源在于编写Js的人对Js的认知

2. 可观的说没有不好的技术,只有没有用好的技术,所以在实现一些功能时,首先要确认,网页增加这种额外的功能是否真的有必要

3. 结构化设计理论推崇一个函数最好只有一个入口点和一个出口点,但现实中我们推荐大家一个函数可以有多个出口点,但是推荐出口点集中在函数的开头部分,最后有一个出口点即可


预留退路:

说明: 当有些浏览器不支持Js或是被禁用,我们应该预留退路,也就是说虽然某些功能无法使用,但是最基本的操作任然能顺利完成

1. 不推荐的做法 - 伪协议法


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>预留退路</title>
</head>
<body>
    <a href="javascript:pop('http://xmdevops.blog.51cto.com/')">
        ζ自动化运维开发之路ζ
        </a>
</body>
<script type="text/javascript">
function pop(url){
    window.open(url, 'xmdevops',    
                  'fullscreen=yes,height=' + screen.height + ',width=' + screen.width + 
            'left=0,location=no'+
            'menubar=no,resizeable=no,scrollbars=yes,status=no,toolbar=no,top=0'
            )
}
</script>
</html>

2. 不推荐的做法 - 事件处理


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>预留退路</title>
</head>
<body>
    <a href="#" onclick="pop('http://xmdevops.blog.51cto.com/');return false">
        ζ自动化运维开发之路ζ
        </a>
</body>
<script type="text/javascript">
function pop(url){
    window.open(url, 'xmdevops',    
                'fullscreen=yes,height=' + screen.height + ',width=' + screen.width + 
                'left=0,location=no'+
                'menubar=no,resizeable=no,scrollbars=yes,status=no,toolbar=no,top=0'
                )
}
</script>
</html>



问题: "javascript:"伪协议让我们可以通过一个链接来调用Js函数,但是一旦浏览器不支持Js或是被禁用Js功能,则此时链接失效,点击什么也不会做,内嵌事件处理,href值为#只是创建一个空链接,实际工作全部由onclick属性完成,但是和伪协议一样糟糕,因为搜索引擎爬取的是带链接的内容,而不认识Js代码

3. 改进后的做法 - 事件处理


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>预留退路</title>
</head>
<body>
    <a href="http://xmdevops.blog.51cto.com/" onclick="pop(this.getAttribute('href'));return false">
        ζ自动化运维开发之路ζ
        </a>
</body>
<script type="text/javascript">
function pop(url){
    window.open(url, 'xmdevops',    
                'fullscreen=yes,height=' + screen.height + ',width=' + screen.width + 
                'left=0,location=no'+
                'menubar=no,resizeable=no,scrollbars=yes,status=no,toolbar=no,top=0'
                )
}
</script>
</html>

说明: 如上方式即时浏览器不支持Js或禁用Js链接依然生效,对搜索引擎也更加友好,但是这样的写法和我们内联CSS的写法似乎更相似,我们更推荐的是大家使用事件绑定的方式来实现Js分离

4. 改进后的做法 - 事件绑定


<html>
    <head>
        <title></title>
        <meta charset="utf-8"/>
        <link rel="stylesheet" href="css/layout.css" />
    </head>
    <body>
        <h1>SnamShots</h1>
    <ul>
        <li>
            <a href="p_w_picpaths/fireworks.jpg" title="a fireworks display">fireworks</a>
        </li>
        <li>
            <a href="p_w_picpaths/coffee.jpg" title="a coffee display">coffee</a>
        </li>
        <li>
            <a href="p_w_picpaths/rose.jpg" title="a rose display">rose</a>
        </li>
        <li>
            <a href="p_w_picpaths/bigben.jpg" title="a bigben display">bigben</a>
        </li>
    </ul>
    <img id="placeholder" src="p_w_picpaths/placeholder.gif" alt="my p_w_picpath gallery" />
    <p id="description">Choose a p_w_picpath.</p>
    <script type="text/javascript" src="js/main.js"></script>
    </body>
</html>

window.load = prepareLinks
function prepareLinks(){
    // 判断浏览器兼容度来决定是否要执行此函数
    if(document.getElementsByTagName) return false
    var links = document.getElementsByTagName('a')
    var placeholder = document.getElementById('placeholder')
    var description = document.getElementById('description')
    for(var i=0; i<links.length; i++){
        links[i].onclick = function(){
            var href = this.getAttribute('href')
            var title = this.getAttribute('title')
            placeholder.setAttribute('src', href)
            description.firstChild.nodeValue = title
            return false
        }
    }
}


循序渐进:


说明: 其实是一种思考问题的方法,从最核心的内容开始,逐步添加额外功能,先用标记语言给核心内容添加正确标记使得获得正确结构,然后在逐步充实被加上的正确标记内容,充实的内容既可以通过CSS样式表实现各种呈现效果也可以通过DOM操作添加各种操作行为


收回控制:


说明: 默认事件譬如鼠标悬停在被设置title属性的元素上时,不同的浏览器可能显示效果不一,我们完全可以通过DOM把隐藏的属性检索出来依据信息创建内容然后插入到文档,来掌握控制权