zoukankan      html  css  js  c++  java
  • New for ASP.NET Web Pages: Conditional attributes

    from:http://www.mikepope.com/blog/AddComment.aspx?blogid=2353 

    March 01, 2012 

    The beta release of ASP.NET Web Pages has been released (for example, as part of the ASP.NET MVC 4 Beta release). There are only a few differences from the December 2011 Developer Preview release. (Details when we've got them posted.)

    A very cool feature is what's being called conditional attributes. The idea is that in markup, you can set the value of an element's attribute to a variable or expression. If the variable or expression returns false or null, the entire attribute is not rendered. There are a variety of uses for this, but it does a great job of solving a problem we inherited from HTML 1.0 (I think it was).

    The problem manifests in cases where the simple appearance of an attribute name — regardless of its value — is sufficient to trigger HTML behavior. One case is the checkbox, i.e., the<input type="checkbox"> element:

    <input type="checkbox" name="check1" value="check1" checked />
    <input type="checkbox" name="check1" value="check1" checked="true" />
    <input type="checkbox" name="check1" value="check1" checked="anyThingAtAll" />


    Notice that in the first one, the checked attribute doesn't even have a value. Nonetheless, all of these work the same, namely they produce checkbox that's selected. 

    There's a similar situation with items in a selection list:

    <select>
    <option value="A">A</option>
    <option value="B" selected>B</option>
    <option value="C">C</option>
    </select>


    Technically, to select item B, the tag should read <option value="B" selected="selected">, but just including the selected attribute works.

    All of this presents a problem when you want to use code in ASP.NET Web Pages to check a checkbox or select a list item. To just set a normal attribute value, you can use inline Razor code like this:

    <input type="text" name="text1" value="@Request.Form["text1"]" />


    But that doesn't work for the checked or selected attributes, since it doesn't matter what you set those attributes to.

    The solution up to now has been to use more elaborate code in the page to render (or not render) the entire attribute, not just its value. Here's one example:

    <input type="checkbox" name="check1" value="check1"
    @if(Request.QueryString["val1"] == "true"){
    <text>checked="checked"</text>
    }
    />


    Or if you were inclined, you could use the C# ternary operator, like this:

    <input type="checkbox" name="check1" value="check1" 
    @(Request.QueryString["val1"] == "true" ? Html.Raw("checked="checked"") : null)
    />


    Anyway, both of these methods were a little clunky. 

    It's now way simpler. As I say, you can now set an attribute to a code value, and if the value is true or non-null, the attribute renders. If it's false or null, the attribute doesn't render. Here's an example:

    @{
    bool check1 = false;
    if(Request.QueryString["val1"] == "true"){
    check1=true;
    }
    }


    Then in the markup:

    <input type="checkbox" name="check1" value="check1" checked="@check1" />


    Magic.

    You have to be careful that you don't assume that this works for all "truthy" and "falsy" values. For example, an empty string is not a false, so you can't return "" in order to kill the attribute. You could do something like this:

    <input type="checkbox" name="check1" value="check1" 
    checked=@(!(Request.QueryString["val1"].IsEmpty())) />


    but this will render the attribute no matter what actual value ("true", "false", "foo") happens to be in the query string for val1.

    Here's a page where you can see in a little more detail how this works. Pass query-string values like ?val1=true or ?val2=true to see what happens.

    @{
    bool checked1=false;
    bool checked2=false;
    Object someObject = null;
    string aString = String.Empty;

    if(Request.QueryString["val1"] == "true"){
    checked1=true;
    }

    if(Request.QueryString["val2"] == "true"){
    checked2=true;
    someObject = this;
    aString="Hello, conditional attributes!";
    }
    }
    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="utf-8" />
    <title>Test Conditional Attributes</title>
    </head>
    <body>

    <form method="post">

    <div>
    <input type="checkbox" name="check1" value="check1" checked="@checked1" />
    Value 1
    <br/>
    <input type="checkbox" name="check2" value="check2" checked="@checked2" />
    Value 2
    <br/>
    <input type="checkbox" name="check3" value="check3" checked="@someObject" />
    Some object
    <br/>
    <input type="checkbox" name="check4" value="check4" checked="@Request.Form["name"]" />
    Request.Form["name"]
    <br/>
    <input type="checkbox" name="check5" value="check5" checked="@aString" />
    aString
    </div>

    <div>
    <input type="submit" name="buttonSubmit" value="Submit" />
    </div>
    </form>
    </body>
    </html>
  • 相关阅读:
    MP3 PQF模块 matlab实现
    Warped Filter
    研究音频编解码要看什么书
    转:Firefox的未来版本可能备有内置视频聊天功能
    SILK,Speex,ISAC,AMRWB区别(1)
    SILK 的 Tilt的意思
    桓泽学音频编码
    整理下最近的学习思路(3月15日~4月9日)
    MPEG4 SSC备选标准SiCAS
    桓泽谈音乐(1)
  • 原文地址:https://www.cnblogs.com/imust2008/p/4986708.html
Copyright © 2011-2022 走看看