最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Backbone underscore Checkbox passing value issue - Stack Overflow

programmeradmin1浏览0评论

I have a very basic issue, but cannot see a solution to it. Maybe I need to change my way of thinking. Basically I am getting a model back in the JSON file, but I can't figure out how to convert true to checked. For example I know the {{-done}} is either true or false.

input type="checkbox"  id="chkName"   <%= {{-done}} ? "checked" : "" %>

I see loads of examples like this, but does not work for me. Is it because of the way I have brought back the true/false value.

Any help would be appreciated

I have a very basic issue, but cannot see a solution to it. Maybe I need to change my way of thinking. Basically I am getting a model back in the JSON file, but I can't figure out how to convert true to checked. For example I know the {{-done}} is either true or false.

input type="checkbox"  id="chkName"   <%= {{-done}} ? "checked" : "" %>

I see loads of examples like this, but does not work for me. Is it because of the way I have brought back the true/false value.

Any help would be appreciated

Share edited Oct 22, 2012 at 21:59 Jack 11k13 gold badges51 silver badges65 bronze badges asked Oct 22, 2012 at 21:54 Mark O KeeffeMark O Keeffe 3013 silver badges15 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 13

Your problem is that you are using the wrong type of Underscore.js template tag, the tag you are using is for interpolating a value and having it HTML-escaped.

To explain, there are three types of tags within underscore templates,

  1. <%= %> - Interpolate - Evaluates the data of the property and prints it.
  2. <%- %> Escape Evaluates the data and prints it HTML-escaped.
  3. <% %> Evaluate Allows you to execute JavaScript in your template.

In addition when executing JavaScript within your template you can use the Print method to print out some text (for example the results of an attribute).

Based on the above in your case you need to run a conditional within your template to print out checked if done evaluates to true. What you can therefore do is something like the following

<% if(done) { %> 'checked="checked" <% } %>

Or you can use the print method

<% print(done ? 'checked="checked"' : '') %>

Edit:

Based on the template you posted, the following template should work

     <script id="item-template"  type="text/template">   
         <input type="checkbox" id="toggle" <% print( done ?  'checked="checked"' : '') %> /> 
           <span class="text">{{-done}}</span>
           <a id="dele" data-role="button" data-inline="true" data-icon='delete' >Delete</a>
        </script>

Here is a link to a jsBin using the default ERB-style delimiters

And here's a second one using mustache style delimiters.

I tought I had it, but its simply always going in to the first condition. This is what I have. As you can see I'm printing out Done on the next line, which is showing true or false. Your code makes sense, just does not want to play ball. Would it be due to the script declaration?

        <div id="items">     
        <script id="item-template"  type="text/template">   
             <input type="checkbox" id="toggle" <% print( done ?  '' : checked) %> 
               <span class="text">{{-done}}</span>
               <a id="dele" data-role="button" data-inline="true" data-icon='delete' >Delete</a>

            </script>
        </div> 
发布评论

评论列表(0)

  1. 暂无评论