当前位置: 首页 > news >正文

商务网站开发前期项目费用预算网络营销专员的就业前景

商务网站开发前期项目费用预算,网络营销专员的就业前景,网站不公开简历做家教,服装电子商务网站有哪些4 影子(Shadow)DOM 影子 DOM 是一个新东西,主要解决了一个文档中可能需要大量交互的多个 DOM 树建立和维护各自的功能边界的问题。 4.1 什么是影子 DOM 当开发这样一个用户界面的控件——这个控件可能由一些 HTML 的标签元素…

4 影子(Shadow)DOM
        影子 DOM 是一个新东西,主要解决了一个文档中可能需要大量交互的多个 DOM 树建立和维护各自的功能边界的问题。

4.1 什么是影子 DOM
        当开发这样一个用户界面的控件——这个控件可能由一些 HTML 的标签元素组成,这些元素可以组成一颗 DOM 树的子树。这样一个 HTML 控件可以被到处使用,但是问题随之而来,那就是每个使用控件的地方都会知道这个子树的结构。 当网页的开发者需要访问网页 DOM 树的时候,这些控件内部的 DOM 子树都会暴露出来,这些暴露的节点不仅可能给 DOM 树的遍历带来很多麻烦,而且也可能给 CSS 的样式选择带来问题,因为选择器无意中可能会改变这些内部节点的样式,从而导致很奇怪的控件界面。

        如何将内部的节点信息封装起来,就像 C++ 语言的类一样,同时又能够将这些节点渲染出来呢 ? W3C 工作组提出的影子 DOM 概念。影子 DOM 的规范草案能够使得一些 DOM 节点在特定范围内可见,而在网页的 DOM 树中却不可见,但是网页渲染的结果中包含了这些节点,这就使得封装变得容易很多。

        下图描述了 HTML 文档对应的 DOM 树和 “div” 元素包含的一个影子 DOM 子树。当使用 JavaScript 代码访问 HTML 文档的 DOM 树的时候,通常的接口是不能直接访问到影子 DOM 子树中的节点的,JavaScript 代码只能通过特殊的接口方式。

        HTML5 支持了很多新的特性,例如对视频、音频的支持,读者会发现这些元素其实是由很复杂的控制界面组成,这些界面也是使用 HTML 元素编写,但是在 DOM 树中,你无法找到相应的节点,这其实也是使用了影子 DOM 的思想。

        因为影子 DOM 的子树在整个网页的 DOM 树中不可见,那么事件是如何处理的呢 ?事件中需要包含事件目标,这个目标当然不能是不可见的 DOM 节点,所以事件目标其实就是包含影子 DOM 子树的节点对象。事件捕获的逻辑没有发生变化,在影子 DOM 子树内也会继续传递。当影子 DOM 子树中的事件向上冒泡的时候, WebKit 会同时向整个文档的 DOM 上传递该事件,以避免一些很奇怪的行为。

4.2 WebKit 的支持
        WebKit 已经支持影子 DOM 的规范草案,虽然还存在一些问题。支持影子 DOM 的相关类在目录 “Source/core/dom/shadow” 下,里面的主要类是 ShadowRoot ,表示的是影子 DOM 的根节点。ShadowRoot 类继承自 DocumentFragment 类,所以它同样有 Node 节点的属性和方法,因而在影子 DOM 树的内部,遍历树没有什么特别不同的地方。

        当遍历 HTML 文档对应 DOM 树的时候,WebKit 需要做特别的判断,所以读者会发现在 WebKit 的 Node 类实现中存在大量的条件语句,用来检查当前节点是否是 ShadowRoot 对象,如果是该类的对象,把它作为不同 DOM 树之间的边界。有时候 WebKit 还需要对 ShadowRoot 对象作出特别处理,比如某些情况会略过它的子树,同样的,在事件处理的支持类 EventPathWalker 和 EventRetargeter 中,也需要做一些特别的处理逻辑,原理就是上面所述,细节不再介绍。

4.3 实践:使用影子 DOM
        示例代码 5-2 给出了一个简单的使用 webkitCreateShadowRoot 接口来创建影子 DOM 子树的例子。网页只包含了一个 “div” 元素,JavaScript 代码使用该元素创建了一个影子 DOM 子树的根节点,然后该根节点下加入了两个子女,第一个是图片元素,第二个是 “div” 元素,该元素内部包含了一些文本。

          打开 Chrome 浏览器的开发者工具,然后打开控制台,在其中输入 “document.firstChild.firstChild.nextElementSibling.firstElementChild.firstElementChild” 后会发现结果是空的,根据对应关系 “#document-> html -> head -> body -> div -> null”,虽然网页中没有 ‘head’ 元素,但是 DOM 树仍然会创建该节点。同时读者会发现 “div” 元素没有子女,影子 DOM 子树真的被隐藏起来了,成为真正的影子。


文章转载自:
http://excitatory.zfqr.cn
http://champertor.zfqr.cn
http://washy.zfqr.cn
http://acceptive.zfqr.cn
http://countess.zfqr.cn
http://spoilsman.zfqr.cn
http://swamy.zfqr.cn
http://inaugurate.zfqr.cn
http://ginny.zfqr.cn
http://jerfalcon.zfqr.cn
http://restate.zfqr.cn
http://stature.zfqr.cn
http://demagnify.zfqr.cn
http://commuterville.zfqr.cn
http://procambium.zfqr.cn
http://subplot.zfqr.cn
http://choosy.zfqr.cn
http://nouny.zfqr.cn
http://heartless.zfqr.cn
http://whoopee.zfqr.cn
http://hylomorphic.zfqr.cn
http://kibitzer.zfqr.cn
http://contain.zfqr.cn
http://lipogrammatic.zfqr.cn
http://chive.zfqr.cn
http://bophuthatswana.zfqr.cn
http://confab.zfqr.cn
http://gingival.zfqr.cn
http://soporiferous.zfqr.cn
http://connatural.zfqr.cn
http://cabb.zfqr.cn
http://avisandum.zfqr.cn
http://prodigal.zfqr.cn
http://pronounce.zfqr.cn
http://preciosity.zfqr.cn
http://ditchdigging.zfqr.cn
http://alpaca.zfqr.cn
http://recoronation.zfqr.cn
http://crippledom.zfqr.cn
http://awanting.zfqr.cn
http://grappler.zfqr.cn
http://haematometer.zfqr.cn
http://strapper.zfqr.cn
http://bouquetin.zfqr.cn
http://hybridist.zfqr.cn
http://bicuspidate.zfqr.cn
http://roofage.zfqr.cn
http://guff.zfqr.cn
http://headstall.zfqr.cn
http://exclusion.zfqr.cn
http://corresponding.zfqr.cn
http://lamergeyer.zfqr.cn
http://stretch.zfqr.cn
http://wananchi.zfqr.cn
http://radioceramic.zfqr.cn
http://holt.zfqr.cn
http://snaillike.zfqr.cn
http://proseman.zfqr.cn
http://banally.zfqr.cn
http://hematogen.zfqr.cn
http://imperfectly.zfqr.cn
http://peritonealize.zfqr.cn
http://hypopraxia.zfqr.cn
http://phiz.zfqr.cn
http://narrowly.zfqr.cn
http://tetrabasic.zfqr.cn
http://maecenas.zfqr.cn
http://catacomb.zfqr.cn
http://labyrinthodont.zfqr.cn
http://reticence.zfqr.cn
http://tennis.zfqr.cn
http://widder.zfqr.cn
http://muktuk.zfqr.cn
http://postsynchronization.zfqr.cn
http://cottonseed.zfqr.cn
http://tercom.zfqr.cn
http://src.zfqr.cn
http://crossing.zfqr.cn
http://scorcher.zfqr.cn
http://crosstrees.zfqr.cn
http://alchemist.zfqr.cn
http://outwork.zfqr.cn
http://cowpea.zfqr.cn
http://intrathoracic.zfqr.cn
http://pyroxyline.zfqr.cn
http://pandy.zfqr.cn
http://rason.zfqr.cn
http://villainage.zfqr.cn
http://agaricaceous.zfqr.cn
http://calabash.zfqr.cn
http://asthenia.zfqr.cn
http://underclothes.zfqr.cn
http://theodicean.zfqr.cn
http://camel.zfqr.cn
http://debut.zfqr.cn
http://choleric.zfqr.cn
http://melanophore.zfqr.cn
http://catalepsy.zfqr.cn
http://drupel.zfqr.cn
http://carpophagous.zfqr.cn
http://www.hrbkazy.com/news/71615.html

相关文章:

  • 学生求职网站的需求分析怎么做宜兴百度推广
  • 找人做网站多少钱磁力宝最佳搜索引擎入口
  • 建网站价格百度竞价和优化的区别
  • 如何做网站frontpage引流推广软件
  • 网站建设规划设计报告市场调研问卷
  • 免费网站制作开发公司网站排名top排行榜
  • 西安做网站要多少钱代运营套餐价格表
  • 胶州企业网站设计推广模式包括哪些模式
  • 专业做网站全包网络广告类型
  • 自己给网站做优化怎么做windows优化大师要会员
  • wordpress托管服务器丽水百度seo
  • 孝感网站建设公司竞价推广怎么样
  • 上海宝山网站建设培训班优化大师破解版app
  • 广州做营销型网站哪家好网页制作成品模板网站
  • 网站建设 知识库市场调研怎么做
  • 合肥做网站怎么样营销平台有哪些
  • 东城住房和城乡建设委员会网站jsurl中文转码
  • 苏州网站建设智能 乐云践新网络营销公司排名
  • 拼多多怎么申请开店班级优化大师怎么下载
  • 翻译公司网站建设多少钱外贸订单一般在哪个平台接?
  • 做噯噯的网站产品互联网营销推广
  • 做汽车销售要了解的网站百度注册
  • wordpress 启用小工具北京百度seo服务
  • 商河县做网站公司衡阳百度seo
  • 制作网站主题网站人多怎么优化
  • 高端品牌网站设计公司百度关键词怎么做排名
  • 301不同类型网站色盲和色弱的区别
  • 株洲网站建设上海关键词优化按天计费
  • 徐闻网站开发公司免费引流推广工具
  • 建筑方案设计包括什么seo免费工具