重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS代码运行实例参考

前言

成都创新互联公司从2013年成立,是专业互联网技术服务公司,拥有项目成都网站制作、成都做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元北关做网站,已为上家服务,为北关各地企业和个人服务,联系电话:13518219792

本篇博文的目的是搜集并汇总一些讲述 web 前端开发技术的书籍中的实例代码,并验证记录其在不同 web 浏览器中的运行结果,以供日后编程参考。

为避免版权问题,所有涉及到的代码片段,都会给出相应的出处和至少在3个浏览器(这里指的是:Microsoft Internet Explorer,Mozilla Firefox,Google Chrome )中的运行结果。

对于比较难以理解的代码片段,会加入自己的思考和总结。另外给出相关作者的联系 e-mail,可以向作者提问,讨论。

                             《准备工具》

gedit 文本编辑器         

用于 linux 环境下的 HTML 文档编写。

firefox 浏览器 

用于运行 HTML 文档并查看输出结果。

firefox 浏览器的 firebug 插件

用于查看 HTML 文档的 DOM 树及其节点,调试 javascript 代码(后面详述),输出CSS样式等等。

IE 浏览器      

用于运行 HTML 文档并查看输出结果。

chrome 浏览器  

用于运行 HTML 文档并查看输出结果。

下面是测试环境使用的 firefox,firebug 版本,以及官方下载地址:

注意,对于部分涉及 HTML5 新特性的代码,建议更新到与下面一致或者更高的版本,才能正确运行或显示预期的输出结果。

【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考

对于 IE 以及 chrome 浏览器,要查看 javascript 的运行结果,可以将代码作为 document.write()的参数调用,这将在浏览器内部窗口为用户显示结果。

document.write()也可以用于同步创建,添加节点到 DOM 树中。

需要注意的是,write()方法会在浏览器加载页面时执行,它会阻塞(中断)对 HTML 文档的解析,优先将传递给它的参数或表达式运行结果输出到页面上,然后

再接续解析 HTML 文档。

对于 firefox 浏览器,在该 html 文档上右击,打开方式选择以 firefox 打开;前面如果已经正确安装 firebug 插件,并且重启 firefox,那么在打开该文档的时刻也会启动 firebug ,建议将其调整在独立的窗口中运行 firebug ,避免在 firefox 主界面下方显示,不便于阅读和调试代码。

在 firebug 的“控制台”选项卡中的底部,键入 console.log(),将要测试运行的代码块作为它的参数调用,回车运行,即可在上面窗口得到输出结果,包括出错提示信息,如下图所示:

这是一种快速实时调试 javascript 代码的方法,并且经测试无误后可以立即集成,部署到你的产品现有代码中,建议熟练掌握。

【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考


注意,在 firebug 的控制台选项卡底部的命令行编辑器中,使用doucument.write()来输出的运行结果,不会显示在控制台上,相反,它会输出到HTML 页面上。只有使用 firebug 内部支持的 console.log,才能直接在控制台上输出:

【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考

 

由此可知,console.log()与doument.write()在输出的位置上不同,而作用是一样的:例如后者可用以 "string",的双引号字符串形式作为其参数输出,前者同样可以,只不过是输出到控制台窗口罢了。

还有就是,在 firebug 命令行编辑器中可以直接输入并运行 javascript,运行结果就会反映到 HTML 页面上。

不需要像传统的浏览器测试法那样,还要加上
        
        
        body {
        background-color: #AFEFEF;  /* use a  light grey background */
        color:           #117755;  /* dark blue test */
        font-family:      Verdana, Helvetica, Arial, sans-serif;
        font-size:      110%;
        }
        
        
        h2 {
        background-color: #CECECE  /* use dark gray */
        ;color:       #000099
        ;border-top:      10px solid #FACABD /* thin blue broder on top */
        ;border-bottom:      5px solid #000099 /* thin blue broder on bottom */
        ;padding:      10px
        ;
        }
        
    
    
    
        

Using Firebug to debugging javascript and coding errors


        

shayi2007
        
        
        
        document.write("this was printed from the html <body> element" + "");
        displayhello();
        /*console.log("shayi")*/
        
        
    

为了方便测试,源码部分有几处略做更动,但并不影响分析与调试工作。

通过阅读源码,可以了解到,

在该 HTML 文档的头部,也就是以 标签定义的部分,将该页面的标题以

标签进行定义,然后通过 <script> 标签引入 javascript,在其中自定义一个叫做 displayhello() 的函数,该函数首先打印一串文字,然后调用浏览器实现的 javascript 内置函数 API,也就是 prompt(),用以弹出一个提示用户输入信息的对话框,并且将获取的字符串保存在一个变量中,最后向页面上输出这个变量的内容,以及后面自定义的字符串。</p><p>接着,定义一个内置的 CSS 样式表,主要是用于设定 HTML 文档体,也就是以 <body> 标签起始的部分,它的背景颜色,字体颜色,字体类型,大小等。</p><p>对于 <body> 标签内部的 <h2> 标签,也就是文档体的主要段落标题部分,使用独立的 CSS 样式定义,注意,它会覆盖对 <body> 部分的样式定义。</p><p>在文档体中,以 <h2> 标签来突出显示主题名称,这个主题名称将套用前面在文档头中为 <h2> 定义的样式。</p><p>可以看到,在文档体中也可以引入 javascript,向页面输出信息,并且调用在文档头部分定义的函数。</p><p><strong>下面,我们刻意在该文档源码的 CSS 部分以及 javascript 部分制造编程的语法错误,借此来测试 firebug 的错误分析与处理能力:</strong></p><p>对于 linux / firefox 开发环境,我们只需以 firefox 打开存储在本地的 HTML 文档,然后启动 firebug 即可:</p><p><img src="/upload/otherpic51/6766.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"></p><p><img src="/upload/otherpic51/6768.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"></p><p>参考上面的 HTML 源码,假设我们在第30行的<code>background-color</code> 属性后面,遗漏了冒号(:) ,然后让浏览器重新加载页面, 此时 firebug 捕捉到的 CSS 语法错误,如下所示:</p><p><img src="/upload/otherpic51/6769.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"></p><p><strong>注意,参考上面源码的第31~34行,可以发现,我故意将分号(;)写在了每个 CSS 属性的前面。</strong></p><p><strong>常规的做法,应该是在上一条 CSS 属性的结尾部分以分号结束,但这里为何要写在下一条 CSS 属性的前面?</strong></p><p><strong>其实,这种写法才符合浏览器解析 CSS 样式的标准逻辑与流程(至少 firefox 是如此),我们可以通过刻意遗漏一个其中的分号来验证,</strong></p><p><strong>例如,我们将源码中第31行最前面的分号丢失,然后用 firefox 重新加载 HTML 文档,查看 firebug 捕捉到的错误提示信息,如下:</strong></p><p><strong><br /></strong></p><p><img src="/upload/otherpic51/6772.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"><strong><br /></strong></p><p>上面的例子也说明,有时通过人为制造错误,并且观察 firebug 的输出,可以学习到浏览器进行语法,词法,语义,以及对其它相关资源进行解析的逻辑。</p><p>从某种意义上而言,这对于前端程序员编写高效率且安全的代码,还是有帮助的。</p><p><strong><br /></strong></p><p><strong>*****参考上面的源码,假设在第15行中,丢失了变量 thisname 与其后面字符串之间的连接运算符(+ 号),这会导致 javascript 语法错误。</strong></p><p>并且,由于该错误是出现在函数 displayhello() 的定义中,只要这个函数其中任何部分出现语法错误, firebug 都会将该函数视为“未定义”,导致后面调用该函数时无法执行,程序流程会中断在该函数调用点。</p><p>下面的截图验证了这部分内容:</p><p><img src="/upload/otherpic51/6773.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"></p><p><strong><img src="/upload/otherpic51/6776.jpg" alt="【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS 代码运行实例参考"></strong></p><p><strong><br /></strong></p> <br> 分享文章:【web前端开发】浏览器原生API,DOM,Javascript,HTML5,CSS代码运行实例参考 <br> 本文URL:<a href="http://cqcxhl.com/article/gcioso.html">http://cqcxhl.com/article/gcioso.html</a> </div> </div> <div class="other"> <h3>其他资讯</h3> <ul> <li> <a href="/article/deidgde.html">四出口路由器 四口路由器接口怎么插</a> </li><li> <a href="/article/deidggp.html">包含sap系统的制度的词条</a> </li><li> <a href="/article/deidgdh.html">linux基本常用命令 linux的常用命令总结</a> </li><li> <a href="/article/deidgji.html">linux常用命令打印 linux命令行打印</a> </li><li> <a href="/article/deidgee.html">阿里云服务器特色 阿里云服务器特色是什么</a> </li> </ul> </div> </div> <div class="footer"> <div class="footer_content"> <div class="footer_content_top clear"> <div class="content_top_share fl"> <div><img src="/Public/Home/img/logo.png"></div> <div class="top_share_content"> <dd>分享至:</dd> <dt class="bdsharebuttonbox clear" id="share"> <a href="#" class="bds_tsina iconfont fl" data-cmd="tsina" title="分享到新浪微博"></a> <a href="#" class="bds_sqq iconfont fl" data-cmd="sqq" title="分享到QQ好友"></a> <a href="#" class="bds_weixin iconfont fl" data-cmd="weixin" title="分享到微信"></a> <a href="#" class="bds_weixin iconfont fl" data-cmd="tieba" title="分享到贴吧"></a> </dt> <script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script> </div> </div> <div class="content_top_left fl clear"> <div class="top_left_list fl"> <dd><a href="/about/">关于我们</a></dd> <dt> <a href="/about/#gsjj">公司简介</a> <a href="/about/#fzlc">发展历程</a> </dt> </div> <div class="top_left_list fl"> <dd><a href="/service/">服务项目</a></dd> <dt> <a href="/service/">高端网站建设</a> <a href="/miniprogram/">小程序开发</a> <a href="/service/app.html">APP开发</a> <a href="/service/yingxiao.html">网络营销</a> </dt> </div> <div class="top_left_list fl"> <dd><a href="/jianzhan/">建站知识</a></dd> <dt> <a href="/jianzhan/2.html">网站建设</a> <a href="/jianzhan/3.html">网站设计</a> <a href="/jianzhan/4.html">网站制作</a> <a href="/jianzhan/5.html">小程序</a> </dt> </div> <div class="top_left_list fl"> <dd><a href="/contact/">联系我们</a></dd> <dt> <a href="/contact/#lxwm">公司地址</a> <a href="/contact/#rczp">人才招聘</a> </dt> </div> </div> <div class="content_top_right addressR fr"> <div class="top_right_title addressf_title"> <a href="javascript:;" class="on">成都</a> <a href="javascript:;">重庆</a> </div> <div class="top_right_content addressf"> <div class="right_content_li on"> <div class="right_content_list clear"> <dd class="fl iconfont"></dd> <dt class="fl">电话:028-86922220</dt> </div> <div class="right_content_list clear"> <dd class="fl iconfont"></dd> <dt class="fl">地址:成都市太升南路288号锦天国际A幢1002号</dt> </div> </div> <div class="right_content_li"> <div class="right_content_list clear"> <dd class="fl iconfont"></dd> <dt class="fl">电话:028-86922220</dt> </div> <div class="right_content_list clear"> <dd class="fl iconfont"></dd> <dt class="fl">地址:重庆市南岸区弹子石腾龙大道58号2栋21-6</dt> </div> </div> </div> </div> </div> </div> <div class="footer_content_copyright clear">版权所有:成都创新互联科技有限公司重庆分公司 <a href="http://beian.miit.gov.cn/" rel="nofollow" target="_blank">渝ICP备2021005571号-4</a> </div> </div> <!--浮窗--> <div class="FloatingWindow clear"> <a href="tencent://message/?uin=1683211881&Site=&Menu=yes" class="FloatingWindow_list fr"> <div class="FloatingWindow_list_title"> <dd class="iconfont"></dd> <dt><span>在线</span>咨询</dt> </div> </a> <a href="javascript:;" class="FloatingWindow_list fr"> <div class="FloatingWindow_list_title"> <dd class="iconfont"></dd> <dt>服务热线</dt> </div> <div class="FloatingWindow_list_down fadeInRight animated">服务热线:028-86922220</div> </a> <a href="javascript:;" class="FloatingWindow_list fr STop"> <div class="FloatingWindow_list_title"> <dd class="iconfont"></dd> <dt>TOP</dt> </div> </a> </div> <script src="/Public/Home/js/jquery-1.8.3.min.js"></script> <script src="/Public/Home/js/comm.js"></script> <script src="/Public/Home/js/wow.js"></script> <script src="/Public/Home/js/common.js"></script> </body> </html> <script> $(".con img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); </script>