精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

解讀ASP.NET 5 & MVC6系列(13):TagHelper

移動開發 Android
這種方式,拋去了服務器端代碼,利用自定義html屬性顯得更加有語義,前端人員開起來也很舒服,極大地提高了前端開發人員的效率。

 在新版的MVC6中,微軟提供了強大的TagHelper功能,以便讓我們擺脫如下的臃腫代碼:

@Html.LabelFor(model => model.FullName)
@Html.EditFor(model => model.FullName)
@Html.ValidationMessageFor(model => model.FullName)

引入新功能TagHelper以后,我們只需要這樣定義就可以了,代碼如下:

  1. @addTagHelper "*, Microsoft.AspNet.Mvc.TagHelpers"  /* 這里需要首先引用TagHelper所在的命名空間 */ 
  2.  
  3. <label asp-for="FullName" class="control-label col-md-2"></label> 
  4. <div class="col-md-10"> 
  5.     <input asp-for="FullName" class="form-control" /> 
  6.     <span asp-validation-for="FullName"></span> 
  7. </div> 

這種方式,拋去了服務器端代碼,利用自定義html屬性顯得更加有語義,前端人員開起來也很舒服,極大地提高了前端開發人員的效率。

在默認的TagHelper實現里,不同的元素支持不同的自定義屬性,以實現不同的用途,例如大部分元素都支持asp-for,而a元素則支持asp-controller和asp-action等,input元素***大的,支持各種類型的type以及相關的格式。詳細實現,請參考如下章節中的表格內容。

A元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

Form元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

 

Input元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

解讀ASP.NET 5 & MVC6系列(13):TagHelper

 

其中關于時間的具體格式如下:

解讀ASP.NET 5 & MVC6系列(13):TagHelper

Label元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

textarea元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

span元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

div元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

驗證描述類型,只有選擇了ValidationSummary.All和ValidationSummary.ModelOnly才能渲染該div元素。

select元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

link元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

link的使用示例如下,比如我們定義如下代碼:

  1. <link rel="stylesheet"  
  2. href="//ajax.aspnetcdn.com/ajax/bootstrap-touch-carousel/0.8.0/css/bootstrap-touch-carousel.css" 
  3. asp-fallback-href="~/lib/bootstrap-touch-carousel/css/bootstrap-touch-carousel.css" 
  4. asp-fallback-test-class="carousel-caption"  
  5. asp-fallback-test-property="display"  
  6. asp-fallback-test-value="none" /> 

 

則該段代碼表示,默認先加載aspnetcdn.com上的css文件,如果加載失敗了,再加載本地網站里的css文件,加載失敗的判斷條件是:檢測carousel-caption樣式十分應用上了,即該應用了該樣式的元素的display屬性是否等于none。運行網站后,這段代碼的生成html如下:

  1. <link rel="stylesheet" href="//ajax.aspnetcdn.com/ajax/bootstrap-touch-carousel/0.8.0/css/bootstrap-touch-carousel.css" /> 
  2. <meta name="x-stylesheet-fallback-test" class="carousel-caption" /> 
  3. <script> 
  4.     !function (a, b, c) { 
  5.         var d, e = document
  6.             f = e.getElementsByTagName("SCRIPT"), 
  7.             g = f[f.length - 1].previousElementSibling, 
  8.             h = e.defaultView && e.defaultView.getComputedStyle ? e.defaultView.getComputedStyle(g) : g.currentStyle; 
  9.  
  10.         if (h && h[a] !== b) { 
  11.             for (d = 0; d < c.length; d++) { 
  12.                 e.write('<link rel="stylesheet" href="' + c[d] + '"/>') 
  13.             } 
  14.         } 
  15.     }("display", "none", ["\/lib\/bootstrap-touch-carousel\/css\/bootstrap-touch-carousel.css"]); 
  16. </script> 

 

 

 

從中,我們看到,生成的HTML代碼在link元素之后多了兩個元素,一個是帶有class="carousel-caption"屬性的meta元素,一個是script腳本標簽。其主要原理是如下:

在meta元素上應用定義的carousel-caption樣式。

通過JS代碼檢測該meta元素的display屬性是否等于none。

如果不等于none,重新加載本地的備用css文件。

注意,這里的js腳本是利用document.getElementsByTagName("SCRIPT"),獲取***一個SCRIPT標簽的上一個兄弟元素的形式,來獲取meta元素的。

script元素

解讀ASP.NET 5 & MVC6系列(13):TagHelper

script標簽元素的fallback功能,和link元素記載css文件類型,只不過這里判斷的不是class樣式,而是檢測某個對象是否存在,來判斷默認的js文件是否加載成功,示例如下:

  1. <script src="//ajax.aspnetcdn.com/ajax/jquery/jquery-1.10.2.min.js" 
  2.     asp-fallback-src="~/lib/jquery/jquery.min.js" 
  3.     asp-fallback-test="window.jQuery"> 
  4. </script> 

 

生成后的HTML代碼,相對比較簡單,示例如下:

  1. <script src="//ajax.aspnetcdn.com/ajax/jquery/jquery-1.10.2.min.js"> 
  2. </script> 
  3. <script>(window.jQuery||document.write("<script src=\"\/lib\/jquery\/jquery.min.js\"><\/script>"));</script> 

 

 

多生成了一個script標簽元素,然后判斷jQuery對象是否存在,如果不存在則表示加載失敗,那就再加載本地的備用js文件。

Cache

解讀ASP.NET 5 & MVC6系列(13):TagHelper

利用EnvironmentTagHelper來控制不同運行環境的輸出結果

在很多情況下,我們想再開發環境使用一套配置信息,在生產環境又是另外一套,這時候就需要使用條件判斷語句了,不過在新版的MVC中,使用EnvironmentTagHelper提供的Environment元素標簽就可以了,示例如下:

  1. <environment names="Development"> 
  2.     <script src="~/lib/jquery/jquery.js"></script> 
  3.     <script src="~/lib/bootstrap/js/bootstrap.js"></script> 
  4.     <script src="~/lib/hammer.js/hammer.js"></script> 
  5.     <script src="~/lib/bootstrap-touch-carousel/js/bootstrap-touch-carousel.js"></script> 
  6. </environment> 
  7. <environment names="Staging,Production"> 
  8.     <script src="//ajax.aspnetcdn.com/ajax/jquery/jquery-1.10.2.min.js" 
  9.             asp-fallback-src="~/lib/jquery/jquery.min.js" 
  10.             asp-fallback-test="window.jQuery"> 
  11.     </script> 
  12.     <script src="//ajax.aspnetcdn.com/ajax/bootstrap/3.0.0/bootstrap.min.js" 
  13.             asp-fallback-src="~/lib/bootstrap/js/bootstrap.min.js" 
  14.             asp-fallback-test="window.jQuery"> 
  15.     </script> 
  16.     <script src="//ajax.aspnetcdn.com/ajax/hammer.js/2.0.4/hammer.min.js" 
  17.             asp-fallback-src="~/lib/hammer.js/hammer.js" 
  18.             asp-fallback-test="window.Hammer"> 
  19.     </script> 
  20.     <script src="//ajax.aspnetcdn.com/ajax/bootstrap-touch-carousel/0.8.0/js/bootstrap-touch-carousel.js" 
  21.             asp-fallback-src="~/lib/bootstrap-touch-carousel/js/bootstrap-touch-carousel.js" 
  22.             asp-fallback-test="window.Zepto"> 
  23.     </script> 
  24. </environment> 

在上述代碼中,我們定于,如果是Development環境就使用本地的js文件,否則(Staging或Production環境)就先加載cdn的文件(只不過還留有備用方案)。

該names里的值判斷依據是,查找IHostingEnvironment的EnvironmentName屬性,并與其進行比較,然后再進行相應的處理。

自定義TagHelper

MVC所有TagHelper的實現,都繼承了Microsoft.AspNet.Razor.Runtime.TagHelpers.ITagHelper接口,所以我們只要實現該接口就可以實現自定義的TagHelper,該接口的定義如下

  1. public interface ITagHelper 
  2.     int Order { get; } 
  3.     Task ProcessAsync(TagHelperContext context, TagHelperOutput output); 
  4. }

不過,我們一般自定義的時候,只需要繼承該接口的默認實現TagHelper類,并重載其虛方法Process方法即可,如下是幾個示例,我們來詳細研究一下。

1. 在a元素上直接支持controller和action屬性

  1. public class ATagHelper : TagHelper 
  2.     [Activate] 
  3.     public IUrlHelper UrlHelper { get; set; } 
  4.  
  5.     public string Controller { get; set; } 
  6.  
  7.     public string Action { get; set; } 
  8.  
  9.     public override void Process(TagHelperContext context, TagHelperOutput output) 
  10.     { 
  11.         if (Controller != null && Action != null
  12.         { 
  13.             var methodParameters = output.Attributes.ToDictionary(attribute => attribute.Key, 
  14.                                                                     attribute => (object)attribute.Value); 
  15.  
  16.             // 刪除所有的attributes,因為路由里已經可以自動生成了 
  17.             output.Attributes.Clear(); 
  18.  
  19.             output.Attributes["href"] = UrlHelper.Action(Action, Controller, methodParameters); 
  20.  
  21.             output.PreContent.SetContent("My "); 
  22.         } 
  23.     } 
  24. }

2. 自動識別Text文本中的鏈接,并提取出來

  1. [TargetElement("p")] 
  2. public class AutoLinkerTagHelper : TagHelper 
  3.     public override async Task ProcessAsync(TagHelperContext context, TagHelperOutput output) 
  4.     { 
  5.         var childContent = await context.GetChildContentAsync(); 
  6.  
  7.         // Find Urls in the content and replace them with their anchor tag equivalent. 
  8.         output.Content.SetContent(Regex.Replace( 
  9.             childContent.GetContent(), 
  10.             @"\b(?:https?://|www\.)(\S+)\b"
  11.             "$0")); 
  12.     } 
  13. }

3. 條件判斷

定義一個condiction,符合條件才顯示該元素,示例如下(只有Model.Approved為true時才顯示該元素):

  1. © @Model.CopyrightYear - My ASP.NET Application

實現代碼如下:

  1. [TargetElement("div")] 
  2. [TargetElement("style")] 
  3. [TargetElement("p")] 
  4. public class ConditionTagHelper : TagHelper 
  5.     public bool? Condition { get; set; } 
  6.  
  7.     public override void Process(TagHelperContext context, TagHelperOutput output) 
  8.     { 
  9.         // 如果設置了condition,并且該值為false,則不渲染該元素 
  10.         if (Condition.HasValue && !Condition.Value) 
  11.         { 
  12.             output.SuppressOutput(); 
  13.         } 
  14.     } 

4. 自定義元素的TagHelper

如果我們要為自定義元素定義TagHelper,則我們要符合約定規范,示例代碼如下:

  1. public class WebsiteInformationTagHelper : TagHelper 
  2.     public WebsiteContext Info { get; set; } 
  3.  
  4.     public override void Process(TagHelperContext context, TagHelperOutput output) 
  5.     { 
  6.         output.TagName = "section"
  7.         output.PostContent.SetContent(string.Format( 
  8.             " 
  9.  
  10. Version: {0
  11. " + Environment.NewLine + 
  12.             " 
  13.  
  14. Copyright Year: {1
  15. " + Environment.NewLine + 
  16.             " 
  17.  
  18. Approved: {2
  19. " + Environment.NewLine + 
  20.             " 
  21.  
  22. Number of tags to show: {3
  23. " + Environment.NewLine, 
  24.             Info.Version.ToString(), 
  25.             Info.CopyrightYear.ToString(), 
  26.             Info.Approved.ToString(), 
  27.             Info.TagsToShow.ToString())); 
  28.         output.SelfClosing = false
  29.     } 
  30. }

則使用的時候,我們需要使用website-information標簽,并將info屬性賦值一個強類型的值,示例如下:

  1. <website-information info="new WebsiteContext { 
  2.                                 Version = new Version(1, 1), 
  3.                                 CopyrightYear = 1990
  4.                                 Approved = true
  5.                                 TagsToShow = 30 }"/> 

其渲染結果,則是渲染成一個包含4個p元素的section元素。

責任編輯:chenqingxiang 來源: 湯姆大叔的博客
相關推薦

2015-06-17 14:42:04

ASP.NET

2015-06-29 10:00:02

ASP.NETMVC6

2015-06-18 16:39:17

ASP.NET

2015-06-18 14:13:36

ASP.NET

2015-06-18 17:04:22

ASP.NET

2015-06-17 16:01:30

ASP.NET

2015-06-16 15:01:59

ASP.NET 5

2015-06-17 16:45:28

ASP.NET

2015-06-17 17:01:48

ASP.NET

2015-06-17 16:04:36

ASP.NET

2015-06-17 10:16:30

ASP.NET

2015-06-18 17:37:19

ASP.NET

2015-06-17 14:09:36

ASP.NET

2015-06-17 14:16:50

ASP.NET

2015-06-17 14:18:50

ASP.NET

2015-06-18 17:34:25

ASP.NET

2015-06-18 14:25:56

ASP.NET

2014-08-26 09:22:40

ASP.NET MVCRouting

2015-06-30 14:58:20

技術周刊

2009-07-31 12:43:59

ASP.NET MVC
點贊
收藏

51CTO技術棧公眾號

久久综合久久综合久久综合| 91影院成人| 岛国精品视频在线播放| 欧美极品色图| 国产乱叫456在线| 伊人久久成人| 在线午夜精品自拍| av电影中文字幕| 小早川怜子影音先锋在线观看| 中文成人综合网| 96久久精品| 日韩国产亚洲欧美| 黄色成人在线网站| 中文字幕日韩欧美在线 | 日本高清不卡免费| 免费看久久久| 欧美一区二区国产| 色婷婷综合久久久久中文字幕 | 精品人妻伦一二三区久久| 亚洲男女自偷自拍| 精品少妇一区二区30p| 国产高清一区二区三区四区| 97青娱国产盛宴精品视频| 在线视频一区二区免费| 激情小视频网站| 在线观看免费网站黄| caoporn国产精品| 91热精品视频| 中文字幕一区二区三区四区欧美| 亚洲精选国产| 欧美疯狂xxxx大交乱88av| 中文字幕一二三四区| 超碰精品在线观看| 欧美一级国产精品| 在线黄色免费看| 国产成人精品一区二区三区免费| 精品久久久久久久久久国产| 国产免费内射又粗又爽密桃视频| 91九色在线porn| 久久久久国色av免费看影院| 痴汉一区二区三区| 国产www视频| 精品在线视频一区| 国产精品无av码在线观看| 亚洲s码欧洲m码国产av| 亚洲九九精品| 4438全国成人免费| 国产精品第9页| 一区在线播放| 性欧美办公室18xxxxhd| 久久国产精品波多野结衣| 欧美99在线视频观看| 久热精品在线视频| 国产大学生自拍| 欧美 日韩 国产一区二区在线视频| www.亚洲天堂| 欧美人禽zoz0强交| 国产精品扒开腿做爽爽爽软件| 久久久999国产| 深夜福利影院在线观看| 欧美在线亚洲综合一区| 欧美精品在线免费播放| 欧美精品xxxxx| 激情久久婷婷| 7777精品视频| 日韩特级黄色片| 丝袜国产日韩另类美女| 国产精品69av| 国产精品无码久久av| 国内成人免费视频| 999日本视频| 人人妻人人澡人人爽精品日本| 成人美女视频在线观看18| 久久久久国产精品视频| 黄色片在线播放| 国产精品日日摸夜夜摸av| 正在播放一区二区三区| 伊人精品影院| 福利一区福利二区微拍刺激| 久久黄色免费看| 日韩三级成人| 亚洲第一精品久久忘忧草社区| 亚洲乱妇老熟女爽到高潮的片| 欧美激情极品| 中文字幕综合在线| 日本天堂中文字幕| 久久av一区二区三区| 国产日韩在线视频| 国产91免费在线观看| 2023国产精品视频| 中文字幕欧美日韩一区二区三区| 美洲精品一卡2卡三卡4卡四卡| 粉嫩老牛aⅴ一区二区三区| 爱情岛论坛亚洲首页入口章节| 国产亚洲久久| 日韩精品久久久久久福利| 精品手机在线视频| 一区二区视频欧美| 国产精品亚洲精品| 色窝窝无码一区二区三区成人网站| 国产亲近乱来精品视频| 国产在线视频综合| 成人看片网页| 精品国产91乱码一区二区三区| 国产真实乱人偷精品人妻| 在线中文字幕亚洲| 日韩免费观看高清| 午夜久久久久久久久久| 久久精品人人爽人人爽| 国产美女永久无遮挡| 日韩经典一区| 亚洲国产精品免费| 国产女人18水真多毛片18精品| 久久天堂成人| 国产精品国产一区二区| 日本高清视频在线观看| 色综合久久久久| 在线中文字日产幕| 综合久久久久| 成人国产精品久久久| 欧洲免费在线视频| 亚洲午夜精品网| 亚洲综合伊人久久| 清纯唯美综合亚洲| 国产精品黄色av| 深夜福利在线观看直播| 亚洲影院久久精品| 婷婷激情小说网| 欧美丰满老妇| 国产精品亚洲激情| www.亚洲.com| 色狠狠综合天天综合综合| 久久久久无码国产精品一区李宗瑞| 色999日韩| 国产精品亚洲片夜色在线| 福利在线观看| 91久久精品一区二区| 黄色录像a级片| 伊人久久成人| 精品国产乱码久久久久久久软件| 欧美色图天堂| 日韩女优电影在线观看| 精品人妻伦九区久久aaa片| 精久久久久久久久久久| 尤物一区二区三区| 亚洲综合伊人| 久久伊人精品视频| 97超碰资源站| 亚洲欧洲成人av每日更新| 久久久久xxxx| 亚洲一区二区三区无吗| 亚洲a成v人在线观看| 超碰在线观看免费| 欧美一区二区三区在线观看视频| 日韩三级在线观看视频| 激情久久五月天| 九九久久九九久久| 日韩精品一区二区三区免费视频| 欧美区二区三区| 亚洲精品一区二区口爆| 五月天精品一区二区三区| 国产高清成人久久| 国产精品入口66mio| 欧美久久综合性欧美| av成人免费| 久久精品中文字幕| 亚洲国产成人一区二区| 粉嫩av一区二区三区免费野| 老熟妇一区二区| 久久精品国内一区二区三区| 黄色高清视频网站| 亚洲精品国产九九九| 国内精品400部情侣激情| 青青操视频在线| 欧美日韩国产首页在线观看| caoporn91| 99视频国产精品| 色婷婷狠狠18| 国内成人在线| 日本黄网免费一区二区精品| 色综合视频一区二区三区44| 欧美激情女人20p| 日本一本草久在线中文| 欧美日韩黄色一区二区| 免费一级a毛片夜夜看 | 精品一区二区三区自拍图片区| 欧美电影h版| 日韩视频在线观看免费| 日本成人动漫在线观看| 91电影在线观看| 99热精品免费| www一区二区| 婷婷中文字幕在线观看| 99国产精品99久久久久久粉嫩| 日本成人看片网址| 亚洲日本一区二区三区在线| 国产成人综合亚洲| 日韩免费影院| 一区二区在线视频| 亚洲精品18p| 欧美视频一二三区| 国产成人无码精品久久久久| 国产精品黄色在线观看| jlzzjizz在线播放观看| 狠狠色丁香婷婷综合| 久久人妻精品白浆国产| 欧美精品18| 亚洲图片在线观看| 日韩极品在线| 99在线看视频| 国产成人亚洲一区二区三区| 97超级碰碰人国产在线观看| 成人影院www在线观看| 亚洲人成毛片在线播放| 人妻一区二区三区| 欧美一级午夜免费电影| 中文字幕在线观看视频一区| 偷拍日韩校园综合在线| 国产精品 欧美激情| 国产精品天天看| free性中国hd国语露脸| 国产成人午夜99999| 亚洲精品午夜在线观看| 日韩avvvv在线播放| 久在线观看视频| 在线观看不卡| 国产91在线亚洲| 一区二区影院| 无码人妻精品一区二区三区99v| av在线不卡顿| 欧洲久久久久久| 思热99re视热频这里只精品| 国产精品国产三级国产专区53| 日本久久伊人| 97人人模人人爽人人少妇| 欧美伊人亚洲伊人色综合动图| 日本一区二区不卡| videos性欧美另类高清| 97视频免费在线观看| 国产白丝在线观看| 久久久久久网站| 成人爽a毛片免费啪啪动漫| 欧美成人精品在线播放| 国产乱色在线观看| 毛片精品免费在线观看| 最新超碰在线| 欧美日韩国产成人在线| 色www永久免费视频首页在线 | 亚洲精品日产| 国语自产精品视频在线看一大j8 | 欧美日韩国产精品一区二区三区四区| 久草资源在线视频| 国产在视频线精品视频| 国产精品无码永久免费888| 国产又粗又长又黄的视频| 国产精品乱人伦| 日韩一级片大全| 一区二区高清免费观看影视大全| 久久久久久av无码免费网站| 亚洲午夜激情网站| 欧美一级视频免费观看| 欧美天堂在线观看| 懂色av蜜臀av粉嫩av喷吹| 欧美日韩精品免费观看视频 | 日韩av在线高清| 黄色小视频在线免费观看| 中文字幕日韩av| av免费在线观看网址| 欧美日韩爱爱视频| 国产美女高潮在线| 国产精品精品国产| 91精品麻豆| www.久久艹| 香蕉国产成人午夜av影院| 日韩电影大全在线观看| 97在线精品| 你真棒插曲来救救我在线观看| 老司机一区二区三区| 人人爽人人爽av| 成人蜜臀av电影| 毛片aaaaaa| 樱桃国产成人精品视频| 欧美一级特黄视频| 在线电影一区二区三区| 手机看片国产1024| 中文字幕日韩视频| 大香伊人久久| 国产精品自产拍在线观看中文| 91午夜精品| 日本免费一区二区三区| 欧美日韩亚洲一区三区| 国产精品69页| 福利一区二区在线| www..com.cn蕾丝视频在线观看免费版 | 欧美丰满美乳xxx高潮www| 免费观看黄色一级视频| 尤物精品国产第一福利三区| 最新国产在线拍揄自揄视频| 国产999在线观看| 第四色在线一区二区| 亚洲激情电影在线| 亚洲另类视频| www.桃色.com| 亚洲国产成人私人影院tom| 国产精品99无码一区二区| 欧美日韩综合在线免费观看| 三级小视频在线观看| 久久精品视频在线播放| 电影网一区二区| 波多野结衣成人在线| 成人在线免费观看网站| 日本欧美黄色片| 国产suv精品一区二区三区| 色撸撸在线视频| 色综合中文字幕| 日本免费网站在线观看| 超碰97人人做人人爱少妇| 国产精品videossex撒尿| 久久久久久a亚洲欧洲aⅴ| 欧美成人久久| 热久久久久久久久| 国产精品网友自拍| 中文字幕日本视频| 日韩精品在线视频| av老司机在线观看| 99理论电影网| 888久久久| 手机免费av片| 国产精品久久久久天堂| 无码人妻av免费一区二区三区| 亚洲精品videossex少妇| 蜜乳av一区| 国产美女99p| 黄色精品网站| 久久无码专区国产精品s| 一区二区三区日本| 国产精品羞羞答答在线| 日韩中文字幕在线播放| 国产成人精品一区二区三区视频| 日韩欧美亚洲日产国| 久久久久久自在自线| 日本黄色网址大全| 欧美日韩国产在线播放| 五月婷婷深深爱| 97久久国产精品| 日韩电影在线观看完整免费观看| 欧美精品卡一卡二| 国产99久久精品| 国产精久久久久久| 日韩国产精品亚洲а∨天堂免| 女人让男人操自己视频在线观看| 精品视频第一区| 久久精品亚洲| 欧洲性xxxx| 欧美一卡在线观看| 色婷婷av在线| 国产精品区一区二区三在线播放 | 亚洲区小说区图片区qvod按摩| 国产91xxx| 久久久久久久综合日本| 欧美男人天堂网| 另类美女黄大片| 成人福利一区| caopor在线视频| 国产精品久久久久久久蜜臀| 97在线公开视频| 欧美激情在线播放| 人人香蕉久久| 日韩精品你懂的| 伊人色综合久久天天人手人婷| 亚洲国产精品无码久久| 国内自拍欧美激情| 神马影视一区二区| 亚洲综合婷婷久久| 一区二区在线电影| 日韩在线无毛| 国产在线观看一区二区三区 | 欧美日韩在线成人| 国产精品青草久久| 亚洲黄色在线播放| 欧美做受高潮电影o| 天天射综合网视频| 中国一级特黄录像播放 | 高潮一区二区三区乱码| 97av在线视频免费播放| 99精品一区| 玖玖爱在线精品视频| 欧美日韩精品一区二区三区四区| 国产www视频在线观看| 日韩中文字幕一区二区| 国产高清久久久久| 亚洲精品国产无码| 久久久久久久久国产| 久久精品国产68国产精品亚洲| 欧美一级片在线免费观看| 色综合久久88色综合天天 | 一区二区三区不卡在线观看| 人妻精品无码一区二区| 成人字幕网zmw| 三级成人在线视频|