欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
ASP.NET前臺代碼綁定后臺變量方法總結

經(jīng)常會(huì )碰到在前臺代碼中要使用(或綁定)后臺代碼中變量值的問(wèn)題。一般有<%= str%>和<%# str %>兩種方式,這里簡(jiǎn)單總結一下。如有錯誤或異議之處,敬請各位指教。
    一方面,這里所講的前臺即通常的.aspx文件,后臺指的是與aspx相關(guān)聯(lián)的CodeBehind,文件后綴名為.aspx.cs;另一方面,這里的綁定是指用戶(hù)發(fā)出訪(fǎng)問(wèn)某一頁(yè)面指令后,服務(wù)器端在執行過(guò)程中就已經(jīng)將前臺代碼進(jìn)行了賦值,而后生成html格式回傳客戶(hù)端顯示,而并非已經(jīng)顯示到客戶(hù)端后,然后通過(guò)其他方法(如ajax)去服務(wù)器端獲取相應變量。

備注:上面說(shuō)的兩個(gè)文件是常見(jiàn)的代碼隱藏(code-behind)模式,還有一種是代碼嵌入(code-beside, inline)模式,那就是只存在aspx一個(gè)文件,而后臺代碼則寫(xiě)入此文件的<script type="text/javascript" runat="server"></script>之中(還有一些語(yǔ)法上區別),這對于本文討論的問(wèn)題略有影響,因為代碼嵌入是聲明性代碼與C#/VB.NET代碼都一起編譯到一個(gè)類(lèi)里面,而代碼隱藏則將聲明性代碼與C#/VB.NET代碼分開(kāi)幾次進(jìn)行翻譯/編譯,因此前者是局部與局部(partial)的關(guān)系后者基類(lèi)與派生類(lèi)的關(guān)系,但這僅僅影響所能綁定變量的范圍(與修飾符有關(guān)),下面會(huì )提到。以下均以代碼隱藏模式為例。

    一般來(lái)說(shuō),在前臺代碼的三種位置可能會(huì )用到(綁定)后臺變量:

•服務(wù)器端控件屬性或HTML標簽屬性
•JavaScript代碼中
•Html顯示內容的位置(也就是開(kāi)始標簽與結束標簽之間的內容,如<div>這里</div>(Html標簽)或者<asp:Label ID="Label2" runat="server" Text="Label">這里</asp:Label>(服務(wù)器端控件),它作為占位符把變量顯示于符號出現的位置)
    對于第一種位置,有一些約束條件:

    (1)一般的屬性要求是字符串型或數值型(下面會(huì )提到有些服務(wù)器端屬性支持屬性為數據集合);

    (2)并不是所有的屬性都可以綁定變量,有些屬性例如runat屬性必須是"server"常量,即使綁定的字符串是server,也會(huì )導致分析器分析時(shí)出錯;

    (3)有一種屬性,他要求屬性值有約束(類(lèi)型約束,比如服務(wù)器端控件要求TabIndex屬性是short類(lèi)型,或者字符串內容有約束),也應該在綁定時(shí)滿(mǎn)足,否則依然可能編譯時(shí)報錯;

    (4)還一種屬性,雖然屬性本身有約束,但即使綁定的變量不滿(mǎn)足約束,也可以編譯通過(guò),比如input的checked屬性,它只有checked字符串是合法的,但如果通過(guò)綁定獲取到的字符串不是checked,那么這些屬性將有自己內部處理機制,來(lái)保證可以正常使用;

    (5)還要注意,即使對于同一類(lèi)屬性,服務(wù)器端和HTML的屬性的處理機制也不同,同樣是TabIndex(tabIndex),前者如果不滿(mǎn)足,則分析器錯誤,后者則忽略這一問(wèn)題。

    對于第二種位置,一般只要綁定的后臺變量和JavaScript中數據類(lèi)型兼容即可。

    對于第三種位置,如果綁定出現的位置不在服務(wù)器端控件內部,則沒(méi)有約束條件,只要是常量字符串可以出現的位置,均可以綁定。但是對于置于服務(wù)器端控件內部,也就是上面那種<asp:Label ID="Label2" runat="server" Text="Label">這里</asp:Label>的方式,則有約束條件。通過(guò)總結,歸納為四類(lèi)服務(wù)器端控件,如果綁定的代碼出現在這些控件的開(kāi)始和結束標簽之間(這里所說(shuō)的控件,是指如果綁定代碼外有多層的嵌套控件包圍,則是指包圍綁定代碼的最內層控件),有不同的顯示結果:

    (1)約束型控件:這類(lèi)控件要求它的開(kāi)始標簽和結束標簽中只能包含指定的子控件,因此如果在這里出現代碼塊,將編譯錯誤。例如:

<asp:DataList runat="server"></asp:DataList>,在它之間,要求必須嵌套<ItemTemplate></ItemTemplate>。

    (2)非嵌套類(lèi)控件:這類(lèi)控件,不允許在內部嵌套其他控件或標簽,只能是常量字符串,它會(huì )將開(kāi)始標簽和結束標簽中常量字符串內容作為他的屬性。例如上面提到的TextBox,它會(huì )將標簽間內容作為它的Text屬性值。

(3)嵌套類(lèi)控件:這類(lèi)控件,可以嵌套其他任意控件,也可以包含字符串,因此可以正常顯示綁定代碼塊所表示的字符串內容。例如Label控件、Panel等。

(4)數據綁定類(lèi)控件:這類(lèi)控件是ASP.NET提供的服務(wù)器端控件,除了可以綁定普通的變量類(lèi)型,也可以綁定一個(gè)數據集合(只能采取下面的第二種方式實(shí)現)。

    關(guān)于是否加引號:在以上三個(gè)位置使用時(shí),是否應該將<%= str%>或<%# str %>置于單引號或雙引號中呢?對于在不同位置,處理的方式是不同的:(具體請在下面兩種方式的具體介紹時(shí),加以體會(huì ))

    (1)對于第一種位置,由于JavaScript是弱類(lèi)型的,如果綁定時(shí)加引號,顯然就認為就當做字符串來(lái)處理,這始終是正確的;如果綁定時(shí)不加引號,它將認為這是個(gè)數值型的,那么如果獲取的真是數值,當然可以,如果是非數值型,則將產(chǎn)生腳本錯誤,這即使對于JavaScript賦值常量時(shí),也是同樣的:

        var test1 = 123b;//運行時(shí)報錯
        var test2=123;//正確,是數值型
        var test3="123b";//正確,字符串型
    (2)對于第二種位置,經(jīng)過(guò)測試,無(wú)論是對于服務(wù)器端控件屬性還是HTML標簽屬性,加引號總是正確的;如果不加引號,則兩種屬性的處理方式不同:

•對于服務(wù)器端控件屬性,如果綁定的代碼塊不加引號,則編譯時(shí)會(huì )提示“驗證(ASP.NET):特性值前后必須加引號”的警告信息,但是生成為HTML后,對應生成的HTML屬性已經(jīng)被加上引號并獲取了正確的綁定結果,因此加不加引號不會(huì )影響使用,但是建議對于規范的代碼,還是加上為好;
•對于HTML標簽屬性,如果不加引號,則編譯時(shí)會(huì )提示“驗證(XHTML 1.0 Transitional): 特性值前后必須加引號”的警告信息,并且生成為HTML屬性也確實(shí)沒(méi)有加上引號,那么雖然屬性后面確實(shí)是沒(méi)有加上引號的正確的綁定值,但是不一定能展示出想要看到的結果。比如對于input標簽的value屬性,如果綁定的字符串是"    hello world from variable”,則在客戶(hù)端的input顯示出的內容實(shí)際上只是"hello”字符串,生效的屬性值是一個(gè)被截斷的字符串,它從屬性后的一串字符串(若未加引號)的第一個(gè)非空字符開(kāi)始,截止到下一個(gè)空字符的前一個(gè)字符為止(比如對于"      hello world”,結果將是"hello”),因此,加上引號是必須的。
    (3)對于第三種位置,加與不加引號,獲取的值及其顯示均不受影響。

    因此建議,所有綁定表達式都加上引號,作為字符串獲取,然后根據實(shí)際需求,用相應函數進(jìn)行轉換,得到所需要的類(lèi)型。

    另外,這里所說(shuō)的后臺變量是泛指的,包括如下:

•成員變量
•方法或屬性的返回值
•表達式,也就是所有后臺能夠執行的代碼,運行后所得到的值(也就是直接將后臺代碼寫(xiě)在前臺代碼中,記得使用完全限定名或在后臺中using相關(guān)namespace)
•數據集合    后臺變量有一些約束條件,需要滿(mǎn)足:

    (1)變量修飾符要求。變量是靜態(tài)或者實(shí)例字段均可。對于代碼隱藏模式的ASP.NET,以上的所述的變量必須為public或protected類(lèi)型(因為是基類(lèi)與派生類(lèi)的關(guān)系),private或者internal都不行,而代碼嵌入模式則任何修飾符的變量均可訪(fǎng)問(wèn)(一個(gè)類(lèi)內部的關(guān)系)。

    (2)變量類(lèi)型要求。由于前臺屬性一般是字符串類(lèi)型,而JavaScript基本類(lèi)型也就是字符串型、數字型、布爾型,因此對應的變量應該也是這幾種方式,其余類(lèi)型如果不被支持(如復雜類(lèi)型、數組、引用類(lèi)型等),前臺獲取的就是調用了變量的ToString()方法所得到的字符串。因此,在綁定時(shí),要根據情況看是否能進(jìn)行隱式類(lèi)型轉換,必要時(shí)還要用相關(guān)函數來(lái)強制轉換,以保證前臺可以獲得正確的值。當然,對于數據綁定類(lèi)控件,它的有些屬性可以為數據集合,但這時(shí)的綁定只能通過(guò)下面第二種方式才被支持。

    以上是一些概念和基本約束,這些都是兩種方式都應該滿(mǎn)足的,下面具體介紹兩種方式,來(lái)實(shí)現前臺代碼中(以下稱(chēng)為代碼塊)綁定后臺變量的功能。

一. <%= str%>

    此種方式其實(shí)是ASP 時(shí)代就支持的,ASP 通過(guò)包含在 < % 和 %>中的表達式將執行結果輸出到客戶(hù)瀏覽器 , 如:< % =test %>就是將變量test的值發(fā)送到客戶(hù)瀏覽器中。在A(yíng)SP.NET中,這個(gè)表達式依然可以使用,并可以出現在前臺代碼的上述三個(gè)位置,但是要注意,除了上述的一般性約束外,對于控件屬性,還必須是綁定到非服務(wù)器端控件的屬性。另外,它只能綁定上面講的前三種變量類(lèi)型,不支持綁定數據集合。例子如下:

后臺代碼:

public partial class WebForm2 : System.Web.UI.Page
   {
       public string GetVariableStr;//注意變量的修飾符
       protected void Page_Load(object sender, EventArgs e)
       {
           if (!IsPostBack)
           {
               GetVariableStr = "hello world from variable";
           }
       }
       protected string GetFunctionStr()//注意返回值的修飾符
       {
           return "hello world from Function";
       }
   }
前臺代碼:

<html xmlns="<head>
    <title></title>
    <script type="text/javascript">
        function fun() {

            var str = '<%= DateTime.Now %>';
            //前臺位置1,綁定的是第三種變量類(lèi)型(也是第二種方式,?因為Now是個(gè)屬性)
            alert(str);
        }
    </script>
</head>
<body onload="fun()">
    <form id="form1" runat="server">  
        <div>
             <input type="text" value="<%= GetVariableStr %>" />
                                                  <%--前臺位置2,綁定的是成員變量--%>
             "<%= GetFunctionStr() %>"
                                                  <%--前臺位置3,綁定的是一個(gè)方法的返回值>--%>
        </div>
    </form>
</body>
</html>
    一些錯誤的使用:

    之所以說(shuō)第一種綁定方式要用于非服務(wù)器端控件的屬性,是因為如果應用于這些服務(wù)器端屬性時(shí),這些代碼實(shí)際上不被解析。 比如:

<asp:Label ID="Label1" runat="server" Text="<%= GetVariableStr %>"></asp:Label>
<asp:TextBox ID="TextBox1" runat="server" Text="<%= GetVariableStr %>"></asp:TextBox>
則顯示出來(lái)的Label1的文本是空,而TextBox中文本是"<%= GetVariableStr %>”,所以記住,對服務(wù)器端控件的屬性加這樣的代碼塊,將不被解析,而是將這一字符串直接作為屬性值了,所以不是想要的結果。如果引號也不加上,將會(huì )編譯錯誤,提示“服務(wù)器標記不能包含 <% ... %> 構造。”。

    這里結合開(kāi)篇提到的關(guān)于將綁定代碼快置于“Html顯示內容的位置”時(shí),如果在服務(wù)器端控件內,那四類(lèi)控件如何顯示的問(wèn)題。如下:

<asp:Label ID="Label1" runat="server" >"<%= GetVariableStr %>"</asp:Label>
<asp:TextBox ID="TextBox1" runat="server" >"<%= GetVariableStr %>"</asp:TextBox>
    其中,Label1屬于嵌套類(lèi)控件,Label1確實(shí)顯示了正確的結果,TextBox屬于非嵌套類(lèi)控件,TextBox如果用這種方式,將會(huì )產(chǎn)生編譯錯誤,提示“此上下文中不支持代碼塊。”

二. <%# str %>

    ASP.NET 引入了一種新的聲明語(yǔ)法 <%# %>。該語(yǔ)法是在 .aspx 頁(yè)中使用數據綁定的基礎,所有數據綁定表達式都必須包含在這些字符中。這里從用法和適用范圍等方面與第一種綁定方式進(jìn)行區分。

    從出現的位置來(lái)看,除了能出現在第一種代碼塊出現的所有位置外,他還可以出現在服務(wù)器端控件的屬性中。

    從綁定的變量類(lèi)型上看,他還可以配合ASP.NET的數據綁定類(lèi)控件,來(lái)綁定上述的第四種“變量”類(lèi)型,就是數據集合(DropDownList,DataList,DataGrid,ListBox這些是數據綁定類(lèi)控件,數據集合包括ArrayList(數組),Hashtable(哈稀表,DataView(數據視圖),DataReader等)。

    從用法上看,在前臺代碼中除了在相應位置寫(xiě)上<%# %>外,在后臺代碼中,還需要使用DataBind()方法。以下是實(shí)例:

前臺代碼:

<html xmlns="<head>
    <title></title>
    <script type="text/javascript">
        function fun() {

            var str = '<%# DateTime.Now %>';

            alert(str);
        }
    </script>
</head>
<body onload="fun()">
    <form id="form1" runat="server">
    <div>
        <input type="text" value="<%# GetVariableStr %>" /><br />
        "<%# GetVariableStr %>"
        <asp:Label ID="Label1" runat="server" Text="<%# GetVariableStr %>"></asp:Label>
            <%--此種方式可以綁定服務(wù)器端控件的屬性--%>
        <asp:DropDownList ID="DropDownList1" runat="server" DataSource='<%# arraylist %>'>
            <%-- 將集合綁定到數據綁定類(lèi)控件,通過(guò)DataSource屬性來(lái)實(shí)現,從而在下拉框看到集合中的內容--%>
        </asp:DropDownList>
        <asp:DataList ID="DataList1" runat="server" DataSource='<%# dt %>'>
            <%-- 同上,綁定了DataTable數據集合?--%>
            <ItemTemplate>
                <table border="1" cellpadding="0" cellspacing="0">
                    <tr>
                      <td>
                       <asp:Label ID="Label2" runat="server" Text='<%# Bind("row0")%>'></asp:Label>
                       <%--由于綁定的數據集合具有多列,并且此數據綁定類(lèi)控件支持模板,
                           因此需要在模板中指定需要綁定的列以及格式--%>
                      </td>
                      <td>
                       <%# Eval("row1")%>
                      </td>
                    </tr>
                </table>
            </ItemTemplate>
        </asp:DataList>
    </div>
    </form>
</body>
</html>
    可以看出,這種方式在使用時(shí),不但可以實(shí)現(取代)<%=... %>所滿(mǎn)足的功能,還可以綁定服務(wù)器控件屬性(如上面的Label1),也可以將集合類(lèi)型綁定到支持的數據綁定類(lèi)控件。在用法上,前臺代碼除了對數據綁定類(lèi)控件綁定數據集合外有所差別,其他的使用上與第一種沒(méi)區別。在綁定類(lèi)控件的模板中,如何使用Eval、Bind、DataBinder.Eval等,不在此文討論中,可以參考下面鏈接的參考文章。

后臺代碼:

public partial class WebForm2 : System.Web.UI.Page
{
    public string GetVariableStr;
    public ArrayList arraylist;
    public DataTable dt;
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            GetVariableStr = "hello world from variable";

            arraylist = new ArrayList();
            arraylist.Add("選?項?1");
            arraylist.Add("選?項?2");

            dt = new DataTable();
            dt.Columns.Add("row0");
            dt.Columns.Add("row1");
            DataRow dr1 = dt.NewRow();
            dr1[0] = "1.1";
            dr1[1] = "1.2";
            DataRow dr2 = dt.NewRow();
            dr2[0] = "2.1";
            dr2[1] = "2.2";
            dt.Rows.Add(dr1);
            dt.Rows.Add(dr2);

            Page.DataBind();
            //DropDownList1.DataBind();
            //DataList1.DataBind();
        }
    }
}
    在后臺代碼中,與第一種方式唯一不同的,就是需要調用DataBind方法。只有執行了相應控件的DataBind方法,前臺代碼中這些控件中使用<%# %>的綁定才會(huì )發(fā)生(并且控件內部的所有綁定也會(huì )發(fā)生,比如又嵌套了一個(gè)綁定后臺數據的控件),否則得話(huà)將不會(huì )被賦值,而是默認空值。上面我們用的是Page的DataBind方法,那么整個(gè)頁(yè)面所有綁定都會(huì )執行。當然,如果我們只執行DataList1或者DropDownList1的DataBind方法,那么只有相應控件的綁定才會(huì )發(fā)生。需要注意的是,這里說(shuō)的需要執行DataBind包括了顯示和隱式執行,有些數據綁定類(lèi)控件,當它們通過(guò) DataSourceID 屬性綁定到數據源控件時(shí),會(huì )通過(guò)隱式調用 DataBind 方法來(lái)執行綁定。這時(shí)就不必顯示的再次調用了。

兩者區別:

    兩種綁定方式上,他們的約束基本相同,都要求與屬性匹配,出現在他們可以出現的位置。后者的使用位置更廣泛,尤其是支持服務(wù)器端控件和綁定數據集合。后臺代碼方面,后者需要調用DataBind才能完成綁定,前者則沒(méi)有這方面要求。這里主要區別一下兩者在執行機制上的區別:<%=...%>是在程序執行時(shí)調用(應該是在頁(yè)面的RenderControl事件過(guò)程中完成的,也就是通常情況下我們可以看到的后臺代碼都執行完畢后再去到前臺代碼中進(jìn)行賦值綁定),而<%#... %>是在DataBind()方法之后被調用,一旦調用了DataBind(),則它對應的控件將綁定變量,因此,請注意:如果在DataBind()后再修改變量,那么綁定的就不是最新值了,這就需要在完成變量的賦值后,再去DataBind()。其實(shí)這兩種方式,它的運行過(guò)程可以在VS中通過(guò)設置斷點(diǎn)來(lái)看看,看兩者的綁定賦值分別是在什么時(shí)候發(fā)生的。

尚存的疑問(wèn):

1.不知道為什么不能獲取到internal修飾的變量?

參考文章:

ASP.NET 數據綁定概述

asp.net代碼中尖括號和百分號的含義

Page.DataBind()方法

Eval( " ")和DataBinder.Eval(Container.DataItem, " ")的區別及用法

體會(huì )Bind和Eval的不同用法

深入理解 ASP.NET 動(dòng)態(tài)控件 (Part 2 - 編譯過(guò)程)

<%# Eval("name")%>與<%# Bind("name")%>區別


本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
ASP.NET數據綁定
asp.net中Bind和Eval的有什么區別_北極狼
ASP.NET編程中的十大技巧
關(guān)于A(yíng)SP.NET 數據綁定
一句代碼實(shí)現批量數據綁定[上篇] - - 博客園
[轉]C# Eval在asp.net中的用法及作用
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久