久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

只有 20 行的 JavaScript 模板引擎實例詳解

瀏覽:135日期:2023-10-28 14:39:54

本文實例講述了 JavaScript 模板引擎。分享給大家供大家參考,具體如下:

原文鏈接:JavaScript template engine in just 20 lines

(譯者吐槽:只收藏不點贊都是耍流氓)

前言

我仍舊在為我的JS預處理器AbsurdJS進行開發工作。它原本是一個CSS預處理器,但之后它擴展成為了CSS/HTML預處理器,很快它將支持JS到CSS/HTML的轉換。它就像一個模板引擎一樣能夠生成HTML代碼,也就是說它能夠用數據填充模板當中的標識片段。

因此,我希望去寫一個可以滿足我當前需求的模板引擎。AbsurdJS主要作為NodeJS的模塊使用,但同時它也可以在客戶端使用。為了這個目的,我無法使用市面上已經存在的模板引擎,因為它們幾乎全都依賴于NodeJS,并且難以在瀏覽器中使用。我需要一個更小,純JS寫成的模板引擎。我瀏覽了這篇由John Resig寫的博客,似乎這正是我需要的東西。我把當中的代碼稍作修改,并且濃縮到了20行。

這段代碼的運行原理非常有趣,我將在這篇文章中一步一步為大家展示John的wonderful idea。

1、提取標識片段

這是我們在開始的時候將要獲得的東西:

var TemplateEngine = function(tpl, data) { // magic here ...}var template = ’<p>Hello, my name is <%name%>. I’m <%age%> years old.</p>’;console.log(TemplateEngine(template, { name: 'Krasimir', age: 29}));

一個簡單的函數,傳入模板和數據作為參數,正如你所想象的,我們想要得到以下的結果:

<p>Hello, my name is Krasimir. I’m 29 years old.</p>

我們要做的第一件事就是獲取模板中的標識片段<%...%>,然后用傳入引擎中的數據去填充它們。我決定用正則表達式去完成這些功能。正則不是我的強項,所以大家將就一下,如果有更好的正則也歡迎向我提出。

var re = /<%([^%>]+)?%>/g;

我們將會匹配所有以<%開頭以%>結尾的代碼塊,末尾的g(global)表示我們將匹配多個。有許多的方法能夠用于匹配正則,但是我們只需要一個能夠裝載字符串的數組就夠了,這正是exec所做的工作:

var re = /<%([^%>]+)?%>/g;var match = re.exec(tpl);

在控制臺console.log(match)可以看到:

[ '<%name%>', ' name ', index: 21, input: '<p>Hello, my name is <%name%>. I’m <%age%> years old.</p>']

我們取得了正確的匹配結果,但正如你所看到的,只匹配到了一個標識片段<%name%>,所以我們需要一個while循環去取得所有的標識片段。

var re = /<%([^%>]+)?%>/g, match;while(match = re.exec(tpl)) { console.log(match);}

運行,發現所有的標識片段已經被我們獲取到了。

2、數據填充與邏輯處理

在獲取了標識片段以后,我們就要對它們進行數據的填充。使用.replace方法就是最簡單的方式:

var TemplateEngine = function(tpl, data) { var re = /<%([^%>]+)?%>/g, match; while(match = re.exec(tpl)) { tpl = tpl.replace(match[0], data[match[1]]) } return tpl;}data = { name: 'Krasimir Tsonev', age: 29}

OK,正常運行。但很明顯這并不足夠,我們當前的數據結構非常簡單,但實際開發中我們將面臨更復雜的數據結構:

{ name: 'Krasimir Tsonev', profile: { age: 29 }}

出現錯誤的原因,是當我們在模板中輸入<%profile.age%>的時候,我們得到的data['profile.age']是undefined的。顯然.replace方法是行不通的,我們需要一些別的方法把真正的JS代碼插入到<%和%>當中,就像以下栗子:

var template = ’<p>Hello, my name is <%this.name%>. I’m <%this.profile.age%> years old.</p>’;

這看似不可能完成?John使用了new Function,即通過字符串去創建一個函數的方法去完成這個功能。舉個栗子:

var fn = new Function('arg', 'console.log(arg + 1);');fn(2); // 輸出 3

fn是個真正的函數,它包含一個參數,其函數體為console.log(arg + 1)。以上代碼等價于下列代碼:

var fn = function(arg) { console.log(arg + 1);}fn(2); // 輸出 3

通過new Function,我們得以通過字符串去創建一個函數,這正是我們所需要的。在創建這么一個函數之前,我們需要去構造這個它的函數體。該函數體應當返回一個最終拼接好了的模板。沿用前文的模板字符串,想象一下這個函數應當返回的結果:

return '<p>Hello, my name is ' + this.name + '. I’m ' + this.profile.age + ' years old.</p>';

顯然,我們把模板分成了文本和JS代碼。正如上述代碼,我們使用了簡單的字符串拼接的方式去獲取最終結果,但是這個方法無法100%實現我們的需求,因為之后我們還要處理諸如循環之類的JS邏輯,像這樣:

var template = ’My skills:’ + ’<%for(var index in this.skills) {%>’ + ’<a href='http://www.gepszalag.com/bcjs/16666.html'><%this.skills[index]%></a>’ +’<%}%>’;

如果使用字符串拼接,結果將會變成這樣:

return’My skills:’ + for(var index in this.skills) { +’<a href='http://www.gepszalag.com/bcjs/16666.html'>’ + this.skills[index] +’</a>’ +}

理所當然這會報錯。這也是我決定參照John的文章去寫邏輯的原因——我把所有的字符串都push到一個數組中,在最后才把它們拼接起來:

var r = [];r.push(’My skills:’); for(var index in this.skills) {r.push(’<a href='http://www.gepszalag.com/bcjs/16666.html'>’);r.push(this.skills[index]);r.push(’</a>’);}return r.join(’’);

下一步邏輯就是整理得到的每一行代碼以便生成函數。我們已經從模板中提取出了一些信息,知道了標識片段的內容和位置,所以我們可以通過一個指針變量(cursor)去幫助我們取得最終的結果:

var TemplateEngine = function(tpl, data) { var re = /<%([^%>]+)?%>/g, code = ’var r=[];n’, cursor = 0, match; var add = function(line) { code += ’r.push('’ + line.replace(/'/g, ’'’) + ’');n’; } while(match = re.exec(tpl)) { add(tpl.slice(cursor, match.index)); add(match[1]); cursor = match.index + match[0].length; } add(tpl.substr(cursor, tpl.length - cursor)); code += ’return r.join('');’; // <-- return the result console.log(code); return tpl;}var template = ’<p>Hello, my name is <%this.name%>. I’m <%this.profile.age%> years old.</p>’;console.log(TemplateEngine(template, { name: 'Krasimir Tsonev', profile: { age: 29 }}));

變量code以聲明一個數組為開頭,作為整個函數的函數體。正如我所說的,指針變量cursor表示我們正處于模板的哪個位置,我們需要它去遍歷所有的字符串,跳過填充數據的片段。另外,add函數的任務是把字符串插入到code變量中,作為構建函數體的過程方法。這里有一個棘手的地方,我們需要跳過標識符<%%>,否則當中的JS腳本將會失效。如果我們直接運行上述代碼,結果將會是下面的情況:

var r=[];r.push('<p>Hello, my name is ');r.push('this.name');r.push('. I’m ');r.push('this.profile.age');return r.join('');

呃……這不是我們想要的。this.name和this.profile.age不應該帶引號。我們改進一下add函數:

var add = function(line, js) { js? code += ’r.push(’ + line + ’);n’ : code += ’r.push('’ + line.replace(/'/g, ’'’) + ’');n’;}var match;while(match = re.exec(tpl)) { add(tpl.slice(cursor, match.index)); add(match[1], true); // <-- say that this is actually valid js cursor = match.index + match[0].length;}

標識片段中的內容將通過一個boolean值進行控制。現在我們得到了一個正確的函數體:

var r=[];r.push('<p>Hello, my name is ');r.push(this.name);r.push('. I’m ');r.push(this.profile.age);return r.join('');

接下來我們要做的就是生成這個函數并且運行它。在這個模板引擎的末尾,我們用以下代碼去代替直接返回一個tpl對象:

return new Function(code.replace(/[rtn]/g, ’’)).apply(data);

我們甚至不需要向函數傳遞任何的參數,因為apply方法已經為我們完整了這一步工作。它自動設置了作用域,這也是為什么this.name可以運行,this指向了我們的data。

3、代碼優化

大致上已經完成了。最后一件事情,我們需要支持更多復雜的表達式,像if/else表達式和循環等。讓我們用同樣的例子去嘗試運行下列代碼:

var template = ’My skills:’ + ’<%for(var index in this.skills) {%>’ + ’<a href='http://www.gepszalag.com/bcjs/16666.html#'><%this.skills[index]%></a>’ +’<%}%>’;console.log(TemplateEngine(template, { skills: ['js', 'html', 'css']}));

結果將會報錯,錯誤為Uncaught SyntaxError: Unexpected token for。仔細觀察,通過code變量我們可以找出問題所在:

var r=[];r.push('My skills:');r.push(for(var index in this.skills) {);r.push('<a href='http://www.gepszalag.com/bcjs/16666.html'>');r.push(this.skills[index]);r.push('</a>');r.push(});r.push('');return r.join('');

包含著for循環的代碼不應該被push到數組當中,而是直接放在腳本里面。為了解決這個問題,在把代碼push到code變量之前我們需要多一步的判斷:

var re = /<%([^%>]+)?%>/g, reExp = /(^( )?(if|for|else|switch|case|break|{|}))(.*)?/g, code = ’var r=[];n’, cursor = 0;var add = function(line, js) { js? code += line.match(reExp) ? line + ’n’ : ’r.push(’ + line + ’);n’ : code += ’r.push('’ + line.replace(/'/g, ’'’) + ’');n’;}

我們添加了一個新的正則。這個正則的作用是,如果一段JS代碼以if, for, else, switch, case, break, |開頭,那它們將會直接添加到函數體中;如果不是,則會被push到code變量中。下面是修改后的結果:

var r=[];r.push('My skills:');for(var index in this.skills) {r.push('<a href='http://www.gepszalag.com/bcjs/16666.html#'>');r.push(this.skills[index]);r.push('</a>');}r.push('');return r.join('');

理所當然的正確執行啦:

My skills:<a href='http://www.gepszalag.com/bcjs/16666.html#' >js</a><a href='http://www.gepszalag.com/bcjs/16666.html#'>html</a><a href='http://www.gepszalag.com/bcjs/16666.html#'>css</a>

接下來的修改會給予我們更強大的功能。我們可能會有更加復雜的邏輯會放進模板中,像這樣:

var template = ’My skills:’ + ’<%if(this.showSkills) {%>’ + ’<%for(var index in this.skills) {%>’ + ’<a href='http://www.gepszalag.com/bcjs/16666.html#'><%this.skills[index]%></a>’ + ’<%}%>’ +’<%} else {%>’ + ’<p>none</p>’ +’<%}%>’;console.log(TemplateEngine(template, { skills: ['js', 'html', 'css'], showSkills: true}));

進行過一些細微的優化之后,最終的版本如下:

var TemplateEngine = function(html, options) { var re = /<%([^%>]+)?%>/g, reExp = /(^( )?(if|for|else|switch|case|break|{|}))(.*)?/g, code = ’var r=[];n’, cursor = 0, match; var add = function(line, js) { js? (code += line.match(reExp) ? line + ’n’ : ’r.push(’ + line + ’);n’) : (code += line != ’’ ? ’r.push('’ + line.replace(/'/g, ’'’) + ’');n’ : ’’); return add; } while(match = re.exec(html)) { add(html.slice(cursor, match.index))(match[1], true); cursor = match.index + match[0].length; } add(html.substr(cursor, html.length - cursor)); code += ’return r.join('');’; return new Function(code.replace(/[rtn]/g, ’’)).apply(options);}

優化后的代碼甚至少于15行。

后記(譯者注)

這是我第一次完整地翻譯文章,語句多有錯漏還請多多諒解,今后將繼續努力,爭取把更多優質的文章翻譯分享。

由于對前端的框架、模板引擎一類的工具特別感興趣,非常希望能夠學習當中的原理,于是乎找了個相對簡單的模板引擎開刀進行研究,google后看到了這篇文章覺得非常優秀,一步步講解生動且深入,代碼經過本人測試均能正確得到文章描述的結果。

模板引擎有多種設計思路,本文僅僅為其中的一種,其性能等參數還有待測試和提高,僅供學習使用。謝謝大家~

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 久久久成人精品 | 久久久久无码国产精品一区 | www..99热 | 亚洲啊v | 99re99| 欧美黄色精品 | 国外成人在线视频 | 亚洲精品3 | 亚洲成人免费网站 | 国产在线视频一区二区 | 黑人巨大精品欧美一区免费视频 | 欧美激情视频久久 | 欧美日韩欧美日韩 | 狠狠做深爱婷婷综合一区 | 91精品久久久久久久久中文字幕 | 嫩草影院网站入口 | 成人二区 | 91精品国产91久久久久游泳池 | 日韩精品一二三区 | 亚洲精品二区 | 日韩一区二区在线免费观看 | 四虎5151久久欧美毛片 | 亚洲美女网站 | 最新中文字幕在线 | 久久久久久亚洲 | 一级黄色片美国 | 免费成人av在线 | 欧美日韩一区在线观看 | 成人日韩av | 日韩视频一区在线观看 | 中文字幕最新在线 | 国产精品不卡 | 欧美a级在线观看 | 亚洲精品一区二区三区在线播放 | 日本理论片好看理论片 | 99精品国产高清在线观看 | 久久伊人国产 | 人人人人澡 | 久久成人精品 | 四虎影院入口 | 国产精品99在线观看 | 亚洲视频二区 | 国产精品久久久久久久久久久免费看 | www.久久久久 | 日韩一区二 | 国产精品国产精品国产专区不片 | 五月婷婷综合激情网 | 九九九视频 | 午夜精品久久久久久久星辰影院 | 免费观看视频www | 中文字字幕一区二区三区四区五区 | 成人三级在线 | 国产成人午夜精品影院游乐网 | 天天摸天天摸 | 伊人久久婷婷 | 91在线高清| 亚洲天堂一区二区 | 狠狠色狠狠色综合网 | 国产精品免费观看 | 欧美中文在线 | 国产精品久久久久久久久 | 久久99精品久久久水蜜桃 | 国产精品久久免费观看spa | 国产精品免费观看 | 凹凸日日摸日日碰夜夜 | 国产精品一区二区三 | 久久小视频 | 海外中文字幕在线观看 | 伊人精品 | 成人超碰在线观看 | av高清在线看 | 欧美精品一区在线发布 | 成人水多啪啪片 | 国产二区三区 | 国产精品国产成人国产三级 | 欧美精三区欧美精三区 | 欧美性一区二区三区 | 成人精品一区二区三区 | 日韩一区二区三区在线播放 | 日韩福利片 | 爱爱精品| 国产一级二级毛片 | 国产精品1区2区 | 亚洲一区二区三区日韩 | 国产成人aⅴ | 精品视频一区二区三区 | 午夜久久久 | 日韩成人精品在线 | 欧美日韩高清 | 日韩视频中文字幕在线观看 | 亚洲精品91 | 国产亚洲欧美在线 | 国产一区二区在线观看视频 | 成人国产精品视频 | 日韩精品免费在线观看 | 日韩精品一区二区三区中文在线 | 成人三级在线 | 中文字幕在线观看 | 日日干夜夜操 | 亚洲国产精品一区二区久久,亚洲午夜 | 国产精品一区二区在线观看 | 天天干狠狠操 | www国产在线观看 | 成av人片在线观看www | 在线成人www免费观看视频 | 成全视频免费观看在线看黑人 | 亚洲精品国产第一综合99久久 | 免费av毛片 | 国产女人高潮视频在线观看 | 九色91视频 | 亚洲一区二区三区免费 | 91偷拍精品一区二区三区 | 国产精品观看 | 亚洲欧美在线一区 | 韩国三级中文字幕hd久久精品 | 日韩精品在线一区 | 国产资源视频在线观看 | 色九九 | 中文字幕日韩在线 | 国产av毛片 | 国产另类一区 | 美女网站视频免费黄 | 国产精品久久久久毛片软件 | 丝袜美腿一区二区三区 | 日韩在线永久免费播放 | 欧美成人精品一区二区男人看 | 日韩免费在线 | 亚洲一二三 | 91电影在线 | 2018自拍偷拍 | 欧美卡一卡二 | caoporn国产精品免费公开 | 国产丝袜人妖ts黄檬 | 9191在线| 五月婷婷综合久久 | 亚洲精品一区二三区不卡 | 久久精品国产亚洲一区二区三区 | 黄色国产大片 | 欧美激情一区二区 | 日韩激情视频一区 | 中文字幕1区 | 日韩精品极品视频在线 | 国产精品视频一区二区三区 | 精品一区二区不卡 | 欧美一区二区三区在线观看视频 | 性一级录像片片视频免费看 | 久久久999成人 | 国产精品美女久久久久久久久久久 | 日韩精品一区二区三区视频播放 | 国产精品免费一区二区 | 国产精品久久久一区二区三区 | 亚洲精品乱码 | 亚洲一区二区三 | 美女久久 | 午夜在线电影 | 亚洲精品一区二区网址 | 国产欧美精品一区二区 | 亚洲无吗电影 | 黄理论视频 | 精品午夜久久 | 国产一区二区自拍 | 国产九九精品视频 | 一区在线观看 | www国产高清| 久久激情综合 | 国产精品777| 成人久久久 | 亚洲一区二区三区四区五区午夜 | av在线播放国产 | 久久久91精品国产一区二区精品 | 色婷网 | 国产美女在线观看 | 国产精品一区二区三区四区 | 视频一区二区中文字幕日韩 | 99热日本 | 国产午夜精品在线 | 午夜a v电影| 色五月激情五月 | 国产91亚洲精品 | 亚洲成人久久久 | 国产一区二区三区在线看 | 国产在线观看一区二区 | 免费欧美视频 | 91亚洲国产成人久久精品网站 | 色综合久久久久 | 国产欧美综合一区二区三区 | 欧美精品欧美精品系列 | 欧美一级网站 | 精品99视频| 99热这里有精品 | 国产小视频在线看 | 亚洲综合视频 | 欧美在线小视频 | 成人网在线观看 | 欧美伦理一区二区三区 | 国产精品综合 | 欧美一区二区三区 | 精品国产一区二区三区久久久蜜月 | 亚洲一区精品视频 | www久久久久 | 91精品国产综合久久久久久丝袜 | 国产精品国产精品国产专区不卡 | 中文字幕一区二区三区四区不卡 | 综合导航 | 青草视频网站 | 羞羞色影院| 美女天天操 | 人人操日日干 | 一区免费视频 | 欧美在线综合 | 国产欧美日韩综合精品一 | 婷婷在线免费视频 | 91久久久久久久 | 一区二区在线影院 | 亚洲欧美日韩精品久久亚洲区 | 成人在线免费视频 | 91视频免费观看网址 | 麻豆一区 | 热久久国产 | 欧美精品亚洲精品 | 999精品嫩草久久久久久99 | 成人看片网 | 成人精品鲁一区一区二区 | 久久男人天堂 | 福利视频一区 | 久久久精品网 | 日韩91| 国产精品久久久久国产a级 91福利网站在线观看 | 日韩激情综合网 | 欧美一级在线 | 欧美经典一区 | 黄瓜av | 美女超碰在线 | 国产精品91久久久久 | 成人欧美一区二区三区视频xxx | 国产精品视频久久久 | 毛片真人毛毛片毛片 | 久久艹99| 午夜久久网站 | www.av7788.com| 国产欧美日韩综合精品一区二区 | av在线免费观看网站 | 成人午夜免费网站 | 在线观看成人高清 | 国产日韩欧美一区二区在线观看 | 伊人网电影 | 欧美精品一区三区 | 午夜影院在线看 | h视频免费在线 | 久久99精品国产99久久6尤 | 午夜专区 | 国产传媒在线视频 | 国偷自产一区二区免费视频 | 亚洲一区在线日韩在线深爱 | 国产精国产精品 | 亚洲欧美日韩在线 | 欧美日韩综合视频 | 中文字幕在线免费视频 | 色综合一区 | 91资源在线 | 精品免费国产 | 日本免费电影一区 | 亚洲成人免费在线 | 日韩精品视频在线 | 久久久久国产一区二区三区四区 | 日韩一区中文 | 中文字幕第一页在线 | 国产一区二区三区精品久久久 | 欧美free性| 视频一区免费观看 | 亚洲成人精品一区二区三区 | 日日干夜夜操 | 91短视频版在线观看www免费 | 国产一区成人 | 一区二区视频在线 | 日韩中文字幕免费在线播放 | 日本免费一区二区视频 | 欧美一级黄| 亚洲三区在线观看 | 亚洲国产视频一区 | av中文字幕网| 久久国产精品久久久久久 | a级性生活片 | 欧美日韩亚洲国内综合网 | 一区二区三区欧美在线 | 中文字幕日韩在线 | 亚洲高清视频在线观看 | 成人综合社区 | 啵啵影院午夜男人免费视频 | a级毛片免费高清视频 | 日韩在线成人 | 欧美日韩视频在线观看免费 | av男人天堂网 | 天天色天天 | 免费大片在线观看网站 | 91精品国产综合久久久久久蜜月 | 91性高湖久久久久久久久_久久99 | 亚洲福利一区二区 | 欧美一级在线播放 | 国产韩国精品一区二区三区 | 国产伦精品一区二区三区四区视频 | 一本色道久久综合狠狠躁篇的优点 | 精品少妇一区二区 | 久久88 | 国产视频大全 | 1204国产成人精品视频 | 国产精品久久久久久中文字 | 精品国产成人 | 99爱爱视频| 激情五月婷婷在线 | 久久不射电影网 | 99久久99久久精品国产片果冻 | 成人在线 | 精品无人乱码区1区2区3区 | 亚洲国产精品久久久男人的天堂 | 国产日韩欧美一区 | 久久国产一区视频 | 日韩五月| 国产精品国产三级国产aⅴ 精品91 | 久久99精品久久久久久园产越南 | 欧美在线激情 | 成人免费crm在线观看 | 久久久免费观看 | 懂色中文一区二区在线播放 | 成人午夜 | 一区二区三区高清不卡 | 日韩网站免费观看 | www日本高清| 久久99亚洲精品 | 国产精品久久久久久久久免费丝袜 | 91在线影院 | 久久另类 | 我爱操 | 免费国产黄网站在线观看视频 | 日韩在线观看中文字幕 | 久久在线| 国产成人精品免费 | 小草av | 免费观看电视在线高清视频 | 91精品国产91久久久久久密臀 | 国产成人精品免高潮在线观看 | 国产精品一区二区不卡 | 免费av观看 | 日韩一区二区观看 | 黄桃av| 久免费视频 | 久久一区二区三区四区 | 99亚洲| 日韩精品一区在线 | 在线观看免费视频a | 欧美视频第一页 | 亚洲综合视频 | 久久精品一区视频 | 偷偷干夜夜拍 | 羞羞视频在线免费 | 久久久久久久一区 | 欧美成人精品在线观看 | 久久在线| 精品一区在线 | 91精品国产一区二区三区四区在线 | 欧美日韩不卡合集视频 | 欧美久久久久久 | 一区二区三区精品视频 | 国产激情视频在线观看 | 91一区| 日韩精品一区二区在线观看 | 国产视频久久久 | 久久精品a一级国产免视看成人 | 欧美伊人影院 | 国产91精品一区二区绿帽 | 日韩精品中文字幕在线观看 | 午夜寂寞少妇aaa片毛片 | 二区影院| 美日韩免费视频 | 午夜精品久久久久久久男人的天堂 | 免费人成电影 | 国产精品18久久久久久首页狼 | 免费色在线 | 免费黄色在线视频网址 | 九九免费观看全部免费视频 | 亚洲www啪成人一区二区 | 亚洲欧美激情另类 | 三级日韩 | 欧美日韩精品一二区 | 美女一区二区三区四区 | 国产激情偷乱视频一区二区三区 | 亚洲高清视频在线观看 | 国产a区 | 亚洲一区二区三区欧美 | 夜添久久精品亚洲国产精品 | 亚洲国产成人av | 亚洲欧洲自拍 | 午夜影院免费体验区 | 狠狠入ady亚洲精品经典电影 | 91春色 | 国产精品永久免费自在线观看 | 日韩成人在线播放 | 欧美日韩专区 | 久久免费视频3 | 一区二区三区国产视频 | 亚洲天堂一区二区 | 国产精品伊人影院 | 激情小视频网站 | 91免费在线看 | 国产精品久久久久久亚洲调教 | 视频一区中文字幕 | 欧美久久久久久久久久 | 国产高潮在线观看 | 精品国产视频 | 欧美成人在线网站 | 亚洲精品国产电影 | 精品亚洲成a人片在线观看 国产高清在线 | 日韩1| 国产高清在线不卡 | 久久麻豆视频 | 99视频在线免费观看 | 精品免费国产一区二区三区 | 亚洲欧美精品一区二区三区 | 欧美精品网站 | 精品久久久久久久 | 国产精品国产三级国产aⅴ入口 | 日韩av一区二区在线观看 | 亚洲综合区 | 久久国产精品免费一区二区三区 | 日韩精品一区二 | 成人一区二区三区在线观看 | 欧美成人精品一区二区三区 | 人人做人人澡人人爽欧美 | 国产精品第一 | 国产一区二区在线播放 | a级片网站 | 国产成人精品一区二区三区视频 | 在线永久免费观看日韩a | 久久久久久亚洲 | 国产成人综合av | 在线观看国产一级片 | 97超碰自拍 | 97人人爱| 午夜婷婷丁香 | 91精品国产91久久久久久最新 | 国产精品一区二区久久 | 免费观看在线午夜影视 | 久久精品色欧美aⅴ一区二区 | 天天干天天av | 免费av电影在线观看 | 国产精品一区二区不卡 | 日韩精品一区在线视频 | 97人人超碰 | 精品久久久久久久久久 | 精品国产不卡一区二区三区 | 亚洲乱码国产乱码精品精98午夜 | 另类中文字幕 | 九九热这里只有精品6 | 国产视频一区二区 | 欧美日韩精品一区二区在线播放 | 国产精品91av | 久久久亚洲一区 | 亚洲精品影院在线 | 欧美国产日韩一区 | 在线中文字幕av | 国产午夜精品久久久久久久 | 欧美视频在线播放 | 久久九| 国产中文字幕在线 | 天天操天天操 | 亚洲91| 一区二区日韩 | av在线免费网址 | 视频在线一区 | 久久免费精品视频 | 国产成人精品高清久久 | 国产成人免费视频网站视频社区 | 午夜家庭影院 | 在线免费毛片 | 一区二区三区四区日韩 | 日韩欧美视频一区 | 亚洲成人免费 | 亚洲电影二区 | 爱干在线 | 欧美一级毛片免费观看 | 色综久久 | 成人在线视频观看 | 天天躁日日躁aaaaxxxx | xxxx午夜 | 国产精品一区免费在线观看 | 97久久久国产精品 | 久久久精品国产 | 欧美在线视频网 | 精品视频 免费 | 极品白嫩少妇无套内谢 | 欧美国产精品久久久 | 在线国产区 | 中文字幕一区二区三区不卡 | 国产精品久久久久久久久久99 | 五月天婷婷激情视频 | 亚洲一区二区三区四区在线 | 亚洲高清视频在线 | 伊人久麻豆社区 | 在线播放国产一区二区三区 | 久久精品伊人 | 亚洲精品国品乱码久久久久 | jizz在线播放 | 成年免费观看视频 | 亚洲a在线播放 | 国产精品视频一区二区三区四 | 欧美日韩亚洲视频 | 成人在线国产 | 国产精品视频一区二区三区 | 成人欧美一区二区三区黑人孕妇 | 国产视频久久久久 | 精品久久久久久国产 | jizz中国zz女人18高潮 | 中文字幕av亚洲精品一部二部 | 91一级| 欧美一区二区三区精品 | 草草久久久 | 亚洲第一视频网站 | 国产精品久久久久久久久久免费看 | 国产欧美综合一区二区三区 | 国产精品久久久一区二区 | 亚洲精品视频免费看 | 精品久久久一区二区 | 国产精品欧美日韩在线观看 | 免费看国产一级特黄aaaa大片 | 亚洲欧美第一页 | 天天综合欧美 | 久久只有精品 | 国产二区视频 | 精品999 | 久久tv在线观看 | 中文字幕一区在线观看视频 | 午夜合集 | 国产视频福利一区 | 91春色 | 亚洲视频一区二区 | 伊人yinren22综合开心 | 亚州综合| 欧美精品久久久久久久久久丰满 | 91精品久久久久 | 亚洲精品在线播放 | 真人女人一级毛片免费播放 | 日韩高清国产一区在线 | 欧美二区三区视频 | 欧美二区三区 | 欧美一级二级三级 | 久久99一区二区 | 国产中文一区 | 国产精品毛片一区二区 | 久久成人精品视频 | 亚洲精品日韩激情在线电影 | 欧美日韩久久 | 久久久久无码国产精品一区 | 午夜免费视频 | 亚洲电影一区 | 亚洲成av人片一区二区梦乃 | 日韩av免费| 欧美黄 片免费观看 | 欧美成人手机在线 | 日本狠狠色 | 中文字幕免费观看 | 亚洲综合无码一区二区 | 91视在线国内在线播放酒店 | 精品视频一区二区三区四区 | 久久精品免费视频观看 | 久久com| 日韩精品在线观看视频 | 爱福利视频 | 久久国产日韩 | 久久久91精品国产一区二区三区 | 5060毛片| 亚洲精品视频区 | 美女诱惑av | 欧美精品免费在线观看 | 国产最新网址 | 亚洲中字在线 | 三级av| 99视频免费 | 欧美乱轮| 国产综合视频 | 亚洲一区二区三区四区的 | 一区二区三区亚洲视频 | 在线观看免费视频亚洲 | 图片区 国产 欧美 另类 在线 | 一区二区三区免费 | 久久久精品日本 | 色综合色综合 | 日韩在线中出 | 人人爱超碰 | 成人久久18免费 | 一区二区三区视频免费在线观看 | 国产福利精品一区 | 国产永久免费 | 免费色在线 | 国产一区二区三区久久 | 日韩视频网站在线观看 | 国产一区二区精品丝袜 | 韩日精品| 精品一区二区在线观看 | 一区二区三区四区精品 | 日韩一区二区三区在线视频 | 噜噜噜天天躁狠狠躁夜夜精品 | 一区二区精品在线观看 | 久久久久成人精品 | 亚洲视频一区 | 日韩中文视频 | 人人九九 | av大片 | 久久久国色 | 黄色一级在线播放 | 在线天堂视频 | 色综合免费 | 天堂一区二区三区 | 国产精品高潮呻吟 | 欧美一区二区三区久久精品 | 日韩欧美一级片 |