校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > ASP.NET預定義模板介紹

ASP.NET預定義模板介紹

熱門標簽:海東防封電銷卡 云南外呼系統代理 聊城智能電銷機器人電話 寧德防封版電銷卡 上海市三維地圖標注 南昌自動外呼系統線路 安陸市地圖標注app 西寧電銷外呼系統公司 辦公用地圖標注網點怎么操作

一、 實例演示:通過模板將布爾值顯示為RadioButton

在默認的情況下,不論是對于編輯模式還是顯示模式,一個布爾類型的屬性值總是以一個CheckBox的形式呈現出來。我們創建如下一個表示員工的類型Employee,它具有一個布爾類型的屬性IsPartTime表示該員工是否為兼職。

public class Employee 
 { 
 [DisplayName("姓名")] 
 public string Name { get; set; } 
 [DisplayName("部門")] 
 public string Department { get; set; } 
 [DisplayName("是否兼職")] 
 public bool IsPartTime { get; set; } 
} 

如果我們直接調用HtmlHelperTModel>的EditorForModel方法將一個Employee對象顯示在某個將Employee類型作為Model的強類型View中,下圖體現了默認的呈現效果。我們可以看到表示是否為兼職的IsPartTime屬性對應著一個CheckBox。

現在我們希望的是將所有布爾類型對象顯示為兩個RadioButton,具體的顯示效果如下圖所示。那么我們就可以通過創建一個Model類型為Boolean的View來創建一個模板,使之改變所有布爾類型對象的默認呈現效果。

由于我們需要改變的是布爾類型對象在編輯模式下的呈現形式,所以我們需要將作為模板的分布View定義在EditorTemplates目錄下,這個目錄可以存在于Views/ Shared下,也可以存在于Views/{ControllerName}下。由于ASP.NET MVC是采用數據類型作為匹配條件來尋找對應的模板的,所以我們需要將分部模板View命名為Boolean。下面的代碼片斷體現了這個分部試圖的整個定義,我們通過調用HtmlHelper的RadioButton方法將兩個布爾值(True/False)映射為對應的RadioButton,并且采用table>來布局。

 @model bool 
table> 
 tr> 
 td>@Html.RadioButton("",true,Model)是/td> 
 td>@Html.RadioButton("",false,!Model)否/td> 
 /tr> 
/table> 

值得一提的是,我們沒有指定RadioButton的名稱,而是指定一個空字符串,Html本身會對其進行命名,而命名的依據就是本章介紹的核心:Model元數據。Employee的IspartTime屬性呈現在界面上對應的HTML如下所示,我們可以看到兩個類型為radio的input>元素的name被自動賦上了對應的屬性名稱。美中不足的是它們具有相同的ID,如果希望讓ID具有唯一性,可以對模板進行更加細致的定制。

div class="editor-label">label for="IsPartTime">是否兼職/label>/div> 
div class="editor-field"> 
 table> 
 tr> 
 td>input checked="checked" id="IsPartTime" name="IsPartTime" type="radio" value="True" .../>是/td> 
 td>input id="IsPartTime" name="IsPartTime" type="radio" value="False" />否/td> 
 /tr> 
 /table> 
/div> 

二、預定義模板

上面我們介紹如何通過View的方式創建模板進而控制某種數據類型或者某個目標元素最終在UI界面上的HTML呈現方式,實際上在ASP.NET MVC的內部還定義了一系列的預定義模板。當我們調用HtmlHelper/HtmlHelperTModel>的模板方法對Model或者Model的某個成員進行呈現的時候,系統會根據當前的呈現模式(顯示模式和編輯模式)和Model元數據獲取一個具體的模板(自定義模版或者預定義模版)。由于Model具有顯示和編輯兩種呈現模式,所以定義在ASP.NET MVC內部的默認模版分為這兩種基本的類型。接下來我們就逐個介紹這些預定義模版以及最終的HTML呈現方式。

EmailAddress
該模板專門針對用于表示Email地址的字符串類型的數據成員,它將目標元素呈現為一個href屬性具有“mailto:”前綴的鏈接(a>/a>)。由于該模板僅僅用于Email地址的顯示,所以只在顯示模式下有效,或者說ASP.NET MVC僅僅定義了基于顯示模式的EmailAddress模板。為了演示數據在不同模板下的呈現方式,我們定義了如下一個簡單的數據類型Model,我們通過在屬性Foo上應用UIHintAttribute特性將模板名稱設置為“EmailAddress”。

public class Model 
{ 
 [UIHint("EmailAddress")] 
 public string Foo { get; set; } 
} 

然后在一個基于Model類型的強類型View中,我們通過調用HtmlHelperTModel>的DisplayFor方法將一個具體的Model對象的Foo屬性以顯示模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 

如下的代碼片斷表示Model的Foo屬性對應的HTML,我們可以看到它就是一個針對Email地址的連接。當我們點擊該鏈接的時候,相應的Email編輯軟件(比如Outlook)會被開啟用于針對目標Email地址的郵件編輯。

a href="mailto:foo@gmail.com">foo@gmail.com/a> 

HiddenInput
關于默認模板HiddenInput我們不應該感到模式,前面介紹的HiddenInputAttribute特性就是將表示Model元數據的ModelMetadata對象的TemplateHint屬性設置為HiddenInput。如果目標元素采用HiddenInput模板,在顯示模式下內容會以文本的形式顯示;編輯模式下不僅會以文本的方式顯示其內容,還會生成一個對應的type屬性為“hidden”的input>元素。如果表示Model元數據的ModelMetadata對象的HideSurroundingHtml屬性為True(將應用在目標元素上的特性HiddenInputAttribute的DisplayValue屬性設置為False),不論是顯示模式還是編輯模式下顯示的文本都將消失。

同樣以上面定義的數據類型Model為例,我們通過在Foo屬性上應用UIHintAttribute特性將模板名稱設置為“HiddenInput”。

public class Model 
{ 
 [UIHint("HiddenInput")] 
 public string Foo { get; set; } 
 public bool Bar { get; set; } 
 public decimal Baz { get; set; } 
} 

然后在一個基于Model類型的強類型View中分別調用HtmlHelperTModel>的DisplayFor和EditFor方法將一個具體的Model對象的Foo屬性以顯示和編輯模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.EditorFor(m=>m.Foo) 

分別以兩種模式呈現出來的Foo屬性對應的HTML如下(包含在花括號中的GUID表示屬性值)。第一行是針對顯示模式的,可以看出最終呈現出來僅限于表示屬性值得文本;而編輯模式對應的HTML中不僅包含屬性值文本,還具有一個對應的類型為“hidden”的input>元素。

{42A1E9B7-2AED-4C8E-AB55-78813FC8C233} 
{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}input id="Foo" name="Foo" type="hidden" value="{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}" /> 

現在我們對數據類型Model做一下簡單修改,將應用在屬性Foo上的UIHintAttribute特性替換成HiddenInputAttribute特性,并將其DisplayValue屬性設置成False。

public class Model 
{ 
 [HiddenInput(DisplayValue = false)] 
 public string Foo { get; set; } 
 public bool Bar { get; set; } 
 public decimal Baz { get; set; } 
} 

由于應用在目標元素上的HiddenInputAttribute特新的DisplayValue屬性會最終控制對應ModelMetadata的HideSurroundingHtml屬性,而后者控制是否需要生成用于顯示目標內容的HTML。所以針對針對的Model定義,最終會生成如下一段HTML。

input id="Foo" name="Foo" type="hidden" value="{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}" /> 

Html

如果目標對象的內容包含一些HTML,并需要在UI界面中原樣呈現出來,我們可以采用Html模板。和EmailAddress模板一樣,該模板僅限于顯示模式。為了演示Html模板對目標內容的呈現方法與默認呈現方式之間的差異,我們定義了如下一個數據類型Model。該數據類型具有兩個字符串類型的屬性Foo和Bar,其中Foo上面應用UIHintAttribute特性將模板名稱設置為“Html”。

public class Model 
{ 
 [UIHint("Html")] 
 public string Foo { get; set; } 
 public string Bar { get; set; } 
}

現在我們創建一個具體的Model對象,并將Foo和Bar設置為一段表示鏈接的文本(a href="www.google.com">google.com/a>),最終在一個基于Model類型的強類型View中通過調用HtmlHelperTModel>的DisplayFor方法將這兩個屬性以顯示模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m => m.Bar) 

從如下所示的表示Foo和Bar兩屬性的HTML中我們不難看出:采用Html模板的Foo屬性的內容原樣輸出,而包含在屬性Bar中的HTML都進行了相應的編碼。

a href="www.google.com">google.com/a> lt;a href=quot;www.google.comquot;gt;google.comlt;/agt; 

Text與String

不論是在顯示模式還是編輯模式,Text和String模板具有相同的HTML呈現方式(實際上在ASP.NET MVC內部,兩種模版最終生成的HTML是通過相同的方法產生的)。對于這兩種模版來說,目標內容在顯示模式下直接以文本的形式輸出;而在編輯模式下則對應著一個單行的文本框。

為了演示兩種模版的同一性,我們對上面定義數據類型Model略作修改,在屬性Foo和Bar上應用UIHintAttribute特性并將模版名稱分別設置為String和Text。

public class Model 
{ 
 [UIHint("String")] 
 public string Foo { get; set; } 
 [UIHint("Text")] 
 public string Bar { get; set; } 
} 

然后我們創建一個具體的Model對象,并在一個基于該Model類型的強類型View中通過調用HtmlHelperTModel>的DisplayFor和EditorFor將兩個屬性分別以顯示和編輯模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m => m.Bar) 
@Html.EditorFor(m=>m.Foo) 
@Html.EditorFor(m => m.Bar) 

如下所示的代碼片斷體現了上述四個元素對應的HTML(“Dummy text …”是Foo和Bar的屬性值),可以看到采用了Text和String模板的兩個屬性在顯示和編輯模式下具有相同的呈現方式。編輯模式下輸出的類型為“text”的input>元素表示CSS特性類型的class屬性被設置為“text-box single-line”,意味著這是一個基于單行的文本框。

Dummy text ... 
Dummy text ... 
input class="text-box single-line" id="Foo" name="Foo" type="text" value="Dummy text ..." /> 
input class="text-box single-line" id="Bar" name="Bar" type="text" value="Dummy text ..." /> 

值得一提的是,ASP.NET MVC內部采用基于類型的模板匹配機制,對于字符串類型的數據成員,如果沒有顯式設置采用的模板名稱,默認情況下會采用String模板。

Url

與EmailAddress和Html一樣,模板Url也僅限于顯示模式。對于某個表示為Url的字符串,如果我們希望它最終以一個連接的方式呈現在最終生成的HTML中,我們采用該模板。如下面的代碼片斷所示,我們通過應用UIHintAttribute特性將模板Url應用到屬性Foo中。

public class Model 
{ 
 [UIHint("Url")] 
 public string Foo { get; set; } 
} 

我們創建一個具體的Model對象,并將Foo屬性設置為一個表示Url的字符串“http://www.asp.net”,最后通過如下的方式將該屬性以顯示模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 

如下面的代碼片斷所示,該屬性最終呈現為一個href屬性和文本內容均屬性值得連接(a>/a>)。

a >http://www.asp.net/a> 

 
MultilineText
一般的字符串在編輯模式下會呈現為一個單行的文本框(類型為“text”的input>元素),而MultilineText模板會將表示目標內容的字符串通過一個textarea>元素,該模板僅限于編輯模式。如下面的的代碼片斷所示,我們通過在字符串類型的Foo屬性上應用UIHintAttribute特性將應用的模板設置為MultilineText。

public class Model 
{ 
 [UIHint("MultilineText")] 
 public string Foo { get; set; } 
} 

現在我們創建一個具體的Model對象并通過如下的形式將Foo屬性以編輯模式呈現在某個基于Model類型的強類型View中。

@model Model 
@Html.EditorFor(m=>m.Foo) 

如下所示的代碼片斷表示Model的Foo屬性呈現在UI界面中的HTML(“dummy text …”是是Foo的屬性值),我們可以看到這是一個 textarea >元素。表示CSS樣式類型的class屬性被設置為“text-box multi-line”,意味著它是以多行的效果呈現。

textarea class="text-box multi-line" id="Foo" name="Foo">dummy text .../textarea> 

Password

對于表示密碼字符串來說,在編輯模式下應該呈現為一個類型為“password”的input>元素,使我們輸入的內容以掩碼的形式顯示出來以保護密碼的安全性。在這種情況下我們可以采用Password模板,該模板和MultilineText一樣也僅限于編輯模式。如下面的代碼片斷所示,我們在Model的Foo屬性上應用UIHintAttribute特性將模式名稱設置為“Password”。

public class Model 
{ 
 [UIHint("Password")] 
 public string Foo { get; set; } 
} 

我們創建一個具體的Model對象,并通過如下的形式將Foo屬性以編輯模式呈現在某個基于Model的強類型View中。

@model Model 
@Html.EditorFor(m=>m.Foo) 

該Foo屬性最終會以如下的形式通過一個類型為“Password”的input>元素呈現出來,表示CSS樣式類型的class屬性被設置為“text-box single-line password”,意味著呈現效果為一個單行的文本框。

input class="text-box single-line password" id="Foo" name="Foo" type="password" value="" /> 

Decimal

如果采用Decimal模板,代表目標元素的數字不論其小數位數是多少,都會最終被格式化為兩位小數。在顯示模式下,被格式化的數字直接以文本的形式呈現出來;在編輯模式下則對應著一個單行的文本框架。如下面的代碼片斷所示,我們在數據類型Model中定義了兩個對象類型屬性Foo和Bar,上面應用了UIHintAttribute特性并將模板名稱指定為“Decimal”。

public class Model 
{ 
 [UIHint("Decimal")] 
 public object Foo { get; set; } 
 [UIHint("Decimal")] 
 public object Bar { get; set; } 
} 

我們創建一個具體的Model對象,將它的Foo和屬性分別設置為整數123和浮點數3.1415(4位小數),最終通過如下的形式將它們以顯示和編輯的模式呈現在一個基于Model類型的強類型View中。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m=>m.Bar) 
@Html.EditorFor(m=>m.Foo) 
@Html.EditorFor(m =>m.Bar) 

上述四個元素在最終呈現的UI界面中對應著如下的HTML,我們可以看到最終顯示的都是具有兩位小數的數字。

123.00 
3.14 
input class="text-box single-line" id="Foo" name="Foo" type="text" value="123.00" /> 
input class="text-box single-line" id="Bar" name="Bar" type="text" value="3.14" /> 

Boolean

通過本章最開始的實例演示我們知道一個布爾類型的對象在編輯模式下會以一個類型為“checkbox”的input>元素的形式呈現,實際上在顯示模式下它依然對應著這么一個元素,只是其disabled屬性會被設置為True使之處于只讀狀態。布爾類型的這種默認呈現方式源自“Boolean”模板默認被使用。

當布爾類的目標元素以編輯模式進行呈現的時候,除了生成一個一個類型為“checkbox”的input>元素之外還會附加產生一個類型為“hidden”的input>元素。如下面的代碼片斷所示,這個hidden元素具有與CheckBox相同的名稱,但是值為False,它存在的目的在于當CheckBox沒有被勾選的情況下通過對應的hidden元素向服務區提交相應的值(False),因為沒有被勾選的CheckBox的值是不會包含在請求中的。

input id="Foo" name="Foo" type="checkbox" value="true" /> 
input name="Foo" type="hidden" value="false" /> 

Boolean和String、Decimal以及后面我們介紹的Object一樣屬于是基于CLR類型的模板。由于ASP.NET在內部采用基于類型的模板匹配策略,如果沒有顯示設置采用的模板類型,相應類型的元素會默認采用與之匹配的模板。

Collection

顧名思義,Collection模板用于集合類型的目標元素的顯示與編輯。對應采用該模板的類型為集合(實現了IEnumerable接口)的目標元素,在調用HtmlHelper或者HtmlHelperTModel>以顯示或者編輯模式對其進行呈現的時候,會遍歷其中的每個元素,并根據基于集合元素的Model元數據決定對其的呈現方法。同樣一我們定義的數據類型Model為例,我們按照如下的方式將它的Foo屬性類型改為對象數組,上面應用了UIHintAttribute特性并將模板名稱 設置為“Collection”。

public class Model 
{ 
 [UIHint("Collection")] 
 public object[] Foo { get; set; } 
} 

然后按照下面的方式創建一個包含三個對象的數組,作為數據元素的三個對象類型為別是數字、字符串和布爾,然后將該數組作為Foo屬性創建一個具體的Model對象。

object[] foo = new object[] 
{ 
 123.00, 
 "dummy text ...", 
 true 
}; 
Model model = new Model { Foo = foo }; 

在一個基于Model類型的強類型View中,我們分別調用HtmlHelperTModel>的DisplayFor和EditorFor方法將上面創建的Model對象的Foo屬性以顯示和編輯模式呈現出來。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.EditorFor(m=>m.Foo) 

Model對象的Foo屬性最終呈現出來的HTML如下所示,我們可以看到不論是顯示模式還是編輯模式,基本上就是對集合元素呈現的HTML的組合而已。

123dummy text ...input checked="checked" class="check-box" disabled="disabled" type="checkbox" /> 
input class="text-box single-line" data-val="true" data-val-number="The field Double must be a number." data-val-required="The Double field is required." id="Foo_0_" name="Foo[0]" type="text" value="123" /> 
input class="text-box single-line" id="Foo_1_" name="Foo[1]" type="text" value="dummy text ..." /> 
input checked="checked" class="check-box" data-val="true" data-val-required="The Boolean field is required." id="Foo_2_" name="Foo[2]" type="checkbox" value="true" /> 
input name="Foo[2]" type="hidden" value="false" /> 
Object

我們說過,ASP.NET 內部采用基于類型的模板匹配策略,如果通過ModelMetadata對象表示的Model元數據不能找到一個具體的模板,最終都會落到Object模板上。Object模板對目標對象的呈現方式很簡單,它通過ModelMetadata的Proeprties屬性得到所有基于屬性的Model元數據。針對每個表示屬性Model元數據的ModelMetadata,它會根據DisplayName或者屬性名稱生成一個標簽(實際上是一個內部文本為顯示名稱的div>元素),然后根據元數據將屬性值以顯示或者編輯的模式呈現出來。

 public class Address 
 { 
 [DisplayName("省")] 
 public string Province { get; set; } 
 [DisplayName("市")] 
 public string City { get; set; } 
 [DisplayName("區")] 
 public string District { get; set; } 
 [DisplayName("街道")] 
 public string Street { get; set; } 
} 

針對上面定義得這個表示地址的Address。現在我們創建一個具體的Address對象并通過如下的方式調用HtmlHelperTModel>的DisplayForModel方法將它呈現在以此作為Model的View中。

@model Address 
@Html.DisplayForModel() 

從如下所示的HTML中我們可以看出作為Model的Address對象的所有屬性都以顯示模式呈現出來,而在前面還具有相應的標簽。

div class="display-label">省/div> 
div class="display-field">江蘇省/div> 
div class="display-label">市/div> 
div class="display-field">蘇州市/div> 
div class="display-label">區/div> 
div class="display-field">工業園區/div> 
div class="display-label">街道/div> 
div class="display-field">星湖街328號/div> 

值得一提的是,Object模板在對屬性進行遍歷的過程中,不論是顯示模式還是編輯模式,只會處理非復雜類型。也就是如果屬性成員是一個復雜類型(不能支持從字符串類型的轉換),它不會出現在最終生成的HTML中。

 public class Contact 
 { 
 [DisplayName("姓名")] 
 public string Name { get; set; } 
 [DisplayName("電話")] 
 public string PhoneNo { get; set; } 
 [DisplayName("Email地址")] 
 public string EmailAddress { get; set; } 
 [DisplayName("聯系地址")] 
 public Address Address { get; set; } 
} 

通過上面的代碼片斷,我們定義了一個表示聯系人的數據類型Contact,它具有一個類型的Address的同名屬性。現在我們創建一個具體的Contact對象,并 對包括Address 屬性在內的所有屬性進行初始化,然后通過如下的方式通過調用HtmlHelperTModel>的DisplayForModel方法將它呈現在以此作為Model的View中。

@model Contact 
@Html.DisplayForModel() 

從如下所示的HTML可以看出,Contact的數據成員Address由于是復雜類型,其內容并不會呈現出來。

div class="display-label">姓名/div> 
div class="display-field">張三/div> 
div class="display-label">電話/div> 
div class="display-field">1234567890/div> 
div class="display-label">Email地址/div> 
div class="display-field">zhangsan@gmail.com/div> 

我們可以有兩種方式解決這個問題,其實就是通過為Address類型定義各類專門的模板用于地址信息的顯示和編輯,通過UIHintAttribute特性將此模板名稱應用到Contact的Address屬性上,然后調用DisplayFor/EditorFor將該屬性呈現出來。另一種就是按照類似如如下的方式手工將負責類型屬性成員呈現出來。

@model Contact 
@Html.DisplayForModel() 
div class="display-label">@Html.DisplayName("Address")/div> 
div class="display-field">@(Model.Address.Province + Model.Address.City + Model.Address.District+ Model.Address.Street)/div>

以上就是關于ASP.NET預定義模板介紹,希望對大家的學習有所幫助。

您可能感興趣的文章:
  • ASP.NET中實現模板頁
  • asp.net TemplateField模板中的Bind方法和Eval方法
  • asp.net GridView控件中模板列CheckBox全選、反選、取消
  • asp.net(C#)壓縮圖片,可以指定圖片模板高寬
  • asp.net GridView模板列中實現選擇行功能
  • asp.net下將頁面內容導入到word模板中的方法
  • 使用ASP.NET模板生成HTML靜態頁面的五種方案
  • asp.net 按指定模板導出word,pdf實例代碼
  • asp.net使用npoi讀取excel模板并導出下載詳解
  • ASP.NET網站模板的實現(第2節)

標簽:衢州 青海 洛陽 汕尾 贛州 崇左 平涼 南寧

巨人網絡通訊聲明:本文標題《ASP.NET預定義模板介紹》,本文關鍵詞  ASP.NET,預,定義,模板,介紹,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET預定義模板介紹》相關的同類信息!
  • 本頁收集關于ASP.NET預定義模板介紹的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    91麻豆视频网站| 精品无人码麻豆乱码1区2区 | hitomi一区二区三区精品| 美女mm1313爽爽久久久蜜臀| 91免费版在线看| 99久久婷婷国产| 91美女蜜桃在线| 一级中文字幕一区二区| 中文字幕在线不卡一区二区三区 | 国产成人欧美日韩在线电影| 精品中文字幕一区二区| 精品中文字幕一区二区| 欧美不卡在线视频| 久久美女艺术照精彩视频福利播放 | 国产欧美日韩三区| 在线亚洲免费视频| 在线精品视频一区二区| 国产剧情av麻豆香蕉精品| 国产91高潮流白浆在线麻豆| 国产一区二区久久| 亚洲丝袜美腿综合| 亚洲一区二区在线播放相泽| 亚洲成av人片一区二区| 久久精品72免费观看| 亚洲色图欧美激情| 一区二区高清视频在线观看| 欧美va在线播放| 成人午夜激情视频| 一区二区欧美国产| 日韩黄色免费电影| 国产成人免费在线观看不卡| 午夜日韩在线电影| 亚洲欧美另类在线| 婷婷综合在线观看| 日产国产欧美视频一区精品| 久久er精品视频| 日韩精品电影在线观看| 国产精品女主播av| 久久综合色鬼综合色| 在线亚洲一区二区| 成人黄色电影在线| 欧美精品在线观看一区二区| 国产清纯美女被跳蛋高潮一区二区久久w | 欧美日韩视频在线观看一区二区三区 | 亚洲一二三区视频在线观看| 一区二区三区丝袜| 欧美日韩不卡一区| 综合欧美一区二区三区| 色婷婷综合五月| 欧美色网站导航| 久久国产精品无码网站| 亚洲国产sm捆绑调教视频| 日韩毛片高清在线播放| 欧美日韩黄色一区二区| 国产亚洲va综合人人澡精品| 中日韩av电影| 91精品国产手机| 国产日韩欧美电影| 亚洲视频一区二区免费在线观看 | 欧美吻胸吃奶大尺度电影| 欧美最猛性xxxxx直播| 欧美日韩国产免费一区二区| 国产精品丝袜一区| 中文字幕亚洲一区二区av在线 | 91蜜桃传媒精品久久久一区二区| 91香蕉视频mp4| 欧美日韩aaaaaa| 精品国产不卡一区二区三区| 亚洲国产精品二十页| 欧美日韩视频不卡| 国产.精品.日韩.另类.中文.在线.播放| 一区二区三区久久久| 欧美一区二区三区四区在线观看| 久久久久久一级片| 亚洲影视资源网| 亚洲伦理在线精品| 蜜桃传媒麻豆第一区在线观看| 艳妇臀荡乳欲伦亚洲一区| 久久精品国产精品亚洲精品| 成人av资源网站| 欧美色网一区二区| 久久精品一区二区三区av| 亚洲妇熟xx妇色黄| 91亚洲精品一区二区乱码| 亚洲国产日韩av| 久久久国产精华| 欧美一区二区三区思思人| 一区二区在线观看免费视频播放| 3d成人动漫网站| 日本一区二区三区国色天香 | 精品国产91乱码一区二区三区 | 欧美日韩国产综合一区二区| 国产69精品久久久久777| 91色porny在线视频| 7777精品伊人久久久大香线蕉经典版下载| 成人一区在线观看| 精品国产99国产精品| 欧美日韩aaa| 一区二区三区日韩欧美精品| 国产精品1024| 国产三级精品视频| 亚洲国产精品成人综合色在线婷婷| 亚洲风情在线资源站| 色综合av在线| 亚洲国产成人自拍| 国产高清成人在线| 久久久99免费| 国产一区在线观看麻豆| 日韩欧美精品在线| 日韩欧美国产电影| 欧美视频一区二区在线观看| 国产日产精品一区| 国产精品福利在线播放| 国产精品18久久久久久久久 | 亚洲综合久久久| 亚洲伦在线观看| 麻豆国产一区二区| 91精品蜜臀在线一区尤物| 午夜精品一区在线观看| 国产麻豆精品久久一二三| 精品国精品国产尤物美女| 无码av中文一区二区三区桃花岛| 不卡一区二区中文字幕| 国产福利精品导航| 国产精品日日摸夜夜摸av| 国产成人免费av在线| 国产精品久久久久桃色tv| 久久久另类综合| 亚洲一区二区在线免费观看视频 | 日本成人中文字幕| 久久国产尿小便嘘嘘尿| eeuss鲁片一区二区三区在线看| 综合电影一区二区三区 | 国产视频一区二区在线观看| 成人h动漫精品一区二区| 亚洲乱码中文字幕| 国模套图日韩精品一区二区 | 欧美欧美欧美欧美首页| 91精品国产欧美一区二区18| 美国三级日本三级久久99| wwwwww.欧美系列| 92国产精品观看| 日本美女一区二区| 欧美影片第一页| 国产一区二区三区不卡在线观看 | 国产凹凸在线观看一区二区| 中文字幕一区av| 国产亚洲精久久久久久| 色综合 综合色| 国产精品福利av| 国产精品综合一区二区| 欧美在线999| 亚洲已满18点击进入久久| 亚洲男人的天堂在线aⅴ视频| 色综合久久综合网| 日韩一级片网站| 国产一区二区三区黄视频| 欧美三级视频在线观看| 国产精品三级视频| 欧美午夜电影一区| 国产精品日韩精品欧美在线| 欧美日本免费一区二区三区| 麻豆91精品91久久久的内涵| 91精品国产综合久久香蕉的特点| 成人亚洲一区二区一| 久久福利视频一区二区| 一区二区三区国产精品| 精品国产伦一区二区三区免费| 亚洲国产欧美另类丝袜| 婷婷开心激情综合| 国产精品初高中害羞小美女文| 久久成人麻豆午夜电影| 欧美精品一区二区三区在线播放 | 91麻豆精品国产91| 99re热视频这里只精品| 中文字幕在线一区二区三区| 欧美色图激情小说| 亚洲综合一区二区三区| 久久一夜天堂av一区二区三区| 婷婷综合在线观看| 麻豆精品蜜桃视频网站| 亚洲成人av福利| 日本国产一区二区| 91美女精品福利| 色香蕉久久蜜桃| 一本到高清视频免费精品| 成人在线视频一区二区| 成人黄页在线观看| 久草精品在线观看| 国产麻豆一精品一av一免费| 日韩一区二区三区免费看| 韩国午夜理伦三级不卡影院| 亚洲女人的天堂| 日韩女优视频免费观看| 国产精品女上位| 国产精品污网站| 最新国产の精品合集bt伙计| 欧美三级一区二区| 91精品国产福利在线观看 | 99r精品视频|