- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
" placeholder="Company name"> 现在在 backb-6ren">
我有一个像这样的 template.html 文件:
<script type="text/template" id="form-template">
<input type="text" class="form-control input-sm" style="" id="company"
value="<% if(typeof company!=='undefined') {%><%=company%><% } %>" placeholder="Company name">
</script>
<script type="text/template" id="person-template">
<input type="text" class="form-control input-sm" style="" id="company"
value="<% if(typeof company!=='undefined') {%><%=company%><% } %>" placeholder="Company name">
</script>
现在在 backbone view.js 中我有两个这样的 View
var FormView = Backbone.View.extend({
template: _.template($(formTemplate).filter("#form-template").html()),
render:
function(){this.$el.html(this.template(this.model.toJSON())}
});
var personView = Backbone.View.extend({
template: _.template($(formTemplate).filter("#person-template").html()),
render:
function(){this.$el.html(this.template()}
});
当我呈现表单 View 时,它工作正常,但是当我呈现人物 View 时,即使我不传递任何数据作为数据,我也会将字段预填充为“[object HTMLInputElement]”。
明显的猜测是两个模板都使用 <%=company%> 但如果模板彼此完全分开,为什么会出现问题?
最佳答案
你有两个问题:
id="company"
所以当你把两个模板放在同一个页面上时,你应该预料到会发生奇怪的事情。 id
属性必须是唯一的,否则您不再真正拥有 HTML,您拥有的是某种看起来像 HTML 的东西。<input id="company">
之后在页面中,您有一个 window.company
值为 <input id="company">
的 DOM 节点的属性.第二个问题是您所看到的,但无论如何您都应该修复 1。
下划线模板使用 JavaScript 的 with
允许对象像作用域一样工作。如果with
在提供的对象(在第二个模板中为 company
)中没有找到名称(在本例中为 {}
),然后它沿着作用域链向上寻找名为 company
的变量.因为你有 <input id="company">
已经在 DOM 中,with
会找到window.company
作为company
.在 company
中留下一个 DOM 节点和 typeof company
不会是'undefined'
因此您的模板会在页面上抛出一个字符串化的 DOM 节点。
考虑这个简化的例子:
<script type="text/template" id="form-template">
<input type="text" id="company"><br>
</script>
<script type="text/template" id="person-template">
<%= typeof company %><br>
<%= typeof company !== 'undefined' ? company : '' %>
</script>
然后是一些 JavaScript 来反射(reflect)您的 Backbone 代码在做什么:
var f = _.template($('#form-template').html());
var p = _.template($('#person-template').html());
$('body').append(f());
$('body').append(p());
console.log(window.company);
你应该在页面上看到类似这样的东西:
<input ...>
object
[object HTMLInputElement]
和控制台中的 DOM 节点。
演示:http://jsfiddle.net/ambiguous/sRnuw/
这是一个相当隐蔽的问题,我没有想到干净的解决方案。可能的选择:
确保 id
表单元素上的 s 与模板中的任何属性都不匹配。
确保为模板提供所有属性,即使是空的。这会让你短路 with
在它去寻找东西之前 window
.
使用 variable
_.template
的选项:
By default, template places the values from your data in the local scope via the
with
statement. However, you can specify a single variable name with the variable setting.
参见 _.template
使用 variable
的示例的文档选项。
with
的更好的模板系统诡计。我倾向于使用 Handlebars。关于javascript - 具有公共(public)值的单个文件中的多个下划线模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23848554/
执行此查询 INSERT INTO classes( '_fkUserID', 'date', 'time' ) VALUES ( '1', '2017-07-04', '8:15' ) 给
不知道它是否重复(无法找到要搜索的词,例如 “允许使用 java 字符”)。我在测试面试中遇到了这个问题: 考虑以下类: class _ {_ f; _(){}_(_ f){_ t = f; f =
我需要验证用户的屏幕名称以确保它不能有 多个连字符或下划线 我不希望人们的网名全是标点符号。 这是我到目前为止的验证: public boolean validateScreenName(String
我正在尝试检查我收到的新数据是否针对我持有的对象,我想知道的是,我正在发送的对象的键是否与我当前拥有的对象中的任何键匹配。 所以我捕获了一个像 myObj = [{"one": 1}, {"two":
这是我第一次使用下划线...我有这个简单的 json... "categories" : [ { "tag" : "cat1", "active" : true
一个很简单的问题: 为什么在WPF内容中看不到_(下划线)? 例如内容 显示为"testt"(未显示下划线)。 最佳答案 标签支持助记符(即您可以使用ctrl +(key)赋予它们焦点)。您可以使用
下面是我正在处理的简化逻辑,我想在数组中查找具有匹配位置(文件夹)的文件。 我能够使用普通的 JS 循环来实现此功能,您能建议更好/更简单/类似下划线的方法来实现此类功能吗? // source va
我正在尝试在对象的函数中查找和替换值 我的对象看起来像这样: var testStates = [{ "module": "module1", "customUrl": [
尝试让 _.uniq() 在以下结构上工作: [ {'x' : 1, 'y': 2}, {'x' : 1, 'y': 2}, {'x' : 2, 'y': 3}, {'
明白了: [{ "title": "qq", "dateValuePair": { "date": "2016-04-29T22:00:00.000Z", "va
我不知道这是否可能,但我试图做的是“清理”一个对象。基本想法是我有一个对象的表格(以 Angular ),然后单击我想添加一个新行(控制对象中的一个新项目,但我希望它没有值。我有下划线尝试一下。一些考
所以我有一大堆对象需要将其变成一个小对象。 它有 50-60 个对象,我需要过滤到一个新的对象数组中,其中只有 3 个。 所以看起来像 myOb = {{"ob1": 1},{"ob2": 1},{"
我有一个像这样的对象 - {"house" : red, "car" : green, "apple" : blue}; 并且正在发送另一个带有单个键/值的对象,如下所示 {"apple" : gre
我有一个包含多个对象的数组,例如 var val = [ _id: ["5412fc1bd123cf7016674a92", "5412cf270e9ca9b517b43ca3"],
所以我有一个对象列表,例如 var options = [{"car" : "red"},{"house": "green"},{"dog":"bark"}] 我正在尝试将其转换为一个值数组,
我正在尝试将此数组转换为对象。使用下划线,我想转换这个数组: [ { "id": "parentA", "children": [ { "nam
我正在尝试使用这样的链检索嵌套项目值。我正在遍历的对象如下所示: var testStates = [{ "module": "module1", "customUrl
我有一些内容可编辑的段落,我希望能够在双击时使某些单词加粗下划线。当我双击一个单词时,它会被选中,并显示一个包含 3 个选项的工具提示。但是,单击工具提示选项后,选择就会消失,并且文本不会发生任何更改
要在 CSS 中给文本加下划线,我们可以这样做: h3 {text-decoration:underline;} 然而,这只会强调包含在 h3 标签中的文本。如果想让下划线穿过页面怎么办? 谢谢 最佳
我正在尝试解决我的最后一个问题,但我仍然不知道如何解决它。我的任务是编写一个对数字进行排序的程序,但是:我们的导师给了我们一些处理数字的程序的额外要点,例如:000054667(实际上是 54667)
我是一名优秀的程序员,十分优秀!