在聚合物中构建自注入元素的最佳方法是什么?
What is the best way to build self-injecting elements in polymer?
我试图找出如何最好地构建元素注入自己到其他元素的模板,而不需要改变其他元素模板代码。例子:
<core-scaffold>
<core-header-panel navigation="" flex="">
<core-toolbar id="navheader">
<span>Menu</span>
</core-toolbar>
<core-menu>
<core-item label="One" horizontal="" center="" layout="" class=""></core-item>
<core-item label="Two" horizontal="" center="" layout="" class="core-selected" active=""></core-item>
</core-menu>
</core-header-panel>
<span tool="">Title</span>
<div id="content"><p>If drawer is hidden, press button to display drawer.</p></div>
</core-scaffold>
这是来自聚合物项目的标准代码支架示例。我想在div #content
元素后面的<core-scaffold>
模板中添加聚合物元素通过导入该元素。如果不想要改变现有的元素代码,新元素需要在正确的位置注入自己。
实现这一目标的最佳方法是什么?
在定义要注入自身的元素时,给它一个附加的函数来搜索目标位置并将自身移动到目标位置。
简单示例(运行演示):
<style>
#content {
background-color: rgb(226, 226, 252);
}
</style>
<div id="content">
</div>
<polymer-element name="self-injector">
<template>I'm the self-injector!</template>
<script>
Polymer('self-injector', {
attached: function() {
document.querySelector('#content').appendChild(this);
}
})
</script>
</polymer-element>
<self-injector></self-injector>
这里唯一棘手的问题是如何找到要注入的位置。(例如,你是否假设页面上只有一个核心支架,或者注入元素应该找到最近的一个,等等)。这大部分取决于您和您的用例。您唯一需要知道的是如何查询影子dom。本文将介绍您可能需要的::shadow
和/deep/
选择器。
相关文章:
- 有条件更新d3.js力图中节点的最佳方法
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- 处理浮点错误的最佳方法是什么
- 从数组中删除元素的最佳方法是:javascript/jquery
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- 列出没有 mysql 的元素的最佳方法是什么
- 在jquery库中重新定义方法的最佳方法
- Javascript,用vars创建对象的最佳方法
- 使用 jQuery 从 HTML 中获取某些值的最佳方法
- 在变量中保存值的最佳方法是在应用程序关闭后使用,然后使用apachecordova在android中重新启动
- 在d3.json中使用d3.csv组合多个csv文件数据输入的最佳方法是什么
- 用jasmine测试JavaScriptUI的最佳方法
- 使用javascript:在没有阻止html标记(<b>、<p>等)的情况下,阻止脚本的最佳方法
- 如果我返回表,检查 Ajax 调用是否为 200 OK的最佳方法是什么
- JavaScript - 创建可链接函数时的最佳方法是什么
- 在上下文菜单项单击上显示侧边栏/弹出窗口的最佳方法是什么
- 在 JavaScript 中获取范围的随机数的最佳方法
- 在对象类上实现 jquery 作用域的最佳方法
- 将同步函数包装到承诺中的最佳方法是什么?
- 使用 MVC 删除 JavaScript 中硬编码字符串 Asp.Net 最佳方法