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

您的位置:首頁技術(shù)文章
文章詳情頁

js實現(xiàn)掃雷源代碼

瀏覽:129日期:2024-04-11 15:46:37

經(jīng)過一段時間學(xué)習(xí),對javascript有了一個初步的了解自己制作了一個掃雷,源代碼+詳細注釋放在后面,先看下效果圖。

初始化界面:

js實現(xiàn)掃雷源代碼

游戲界面:

js實現(xiàn)掃雷源代碼

難易程度切換:

js實現(xiàn)掃雷源代碼

游戲結(jié)束:

js實現(xiàn)掃雷源代碼

思路

采用構(gòu)造函數(shù)的形式進行全局開發(fā)

生成游戲棋盤

利用雙層for循環(huán)創(chuàng)建設(shè)定的棋盤大小 為每個單元格的dom元素創(chuàng)建一個屬性,該屬性用于保存單元格的所有信息,如x,y坐標,value,是否為雷等

隨機生成炸彈

利用隨機數(shù),隨機生成炸彈x,y坐標,并將符合該坐標信息的單元格的屬性更改為雷 炸彈是在用戶第一次點擊的時候生成,防止用戶第一次點擊到炸彈 將生成的每個炸彈信息都保存到一個this變量中,方便后續(xù)使用 遍歷每個炸彈周圍的非炸彈方格,每遍歷一次value值+1

鼠標左鍵點擊

點擊的時候需要考慮該單元格是否有被標記小旗子(isFlag屬性),如果有則無法點擊 判斷是雷還是數(shù)字,雷的話則游戲結(jié)束,數(shù)字則繼續(xù)判斷是否等于0,等于0則使用遞歸顯示空白區(qū)域 每次打開一個單元格,需要更改該單元格的isOpen屬性,表示單元格被打開

鼠標右鍵點擊

點擊時需要考慮該單元格的isOpen屬性是否被打開,打開的話則無法點擊 當(dāng)該單元格沒有標記旗幟時標記,如果有標記旗幟則取消標記 每標記一個方格,剩余炸彈數(shù)量-1,取消標記則+1

游戲結(jié)束

當(dāng)左鍵點擊到炸彈的時候游戲結(jié)束。失敗 剩余炸彈數(shù)量為0時。判斷旗幟標記是否正確,正確游戲勝利,標記有誤則失敗

HTML代碼

超短的HTML代碼

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title> <link rel='stylesheet' href='http://www.gepszalag.com/bcjs/css/index.css' ></head><body> <div class='main'> <header class='header'> <button>初級</button> <button>中級</button> <button>高級</button> </header> <div id='gameBox'></div> <footer class='footer'>剩余雷數(shù)量:<span id='surplusMine'></span> </footer> </div></body><script src='http://www.gepszalag.com/bcjs/js/index.js'></script></html>

CSS代碼

.main .header { text-align: center; margin: 20px auto;}.main .gameBox table { border-spacing: 1px; background-color: rgb(170, 170, 170); text-align: center; margin: 20px auto;}.main .gameBox table td.mine { /* 游戲結(jié)束時顯示 */ border: none; background: url(./../img/mine.png) no-repeat; background-size: 90% 90%; background-color: #e9e6e6; background-position: 2px 0;}.main .gameBox table td.targetMine { /* 游戲結(jié)束時顯示,觸發(fā)雷的單元格 */ border: none; background: url(./../img/mine.png) no-repeat; background-size: 90% 90%; background-color: #ff4b4b; background-position: 2px 0;}.main .gameBox table td.targetFlag { /* 右鍵標記方格時顯示 */ background: url(./../img/flag.png) no-repeat; background-size: 90% 90%; background-position: 2px 0; background-color: #e9e6e6;}.main .gameBox table td { /* 單元格初始樣式 */ width: 20px; height: 20px; box-sizing: border-box; border: 2px solid; border-color: #eee #ccc #ccc #eee; background-color: #e9e6e6; font-size: 1px; font-weight: 800;}.gameBox table td.zero,.gameBox table td.one,.gameBox table td.two,.gameBox table td.three,.gameBox table td.four,.gameBox table td.five,.gameBox table td.six,.gameBox table td.seven,.gameBox table td.eight,.gameBox table td.nine { border: none; background-color: rgb(211, 200, 200);}.gameBox table td.zero {}.gameBox table td.one { color: blue;}.gameBox table td.two { color: rgb(5, 93, 5);}.gameBox table td.three { color: #008c8c;}.gameBox table td.four { color: crimson;}.gameBox table td.five { color: rgb(228, 91, 0);}.gameBox table td.six { color: darkorange;}.gameBox table td.seven { color: rgb(193, 196, 50);}.gameBox table td.eight { color: pink;}.main .footer { text-align: center;}

javaScript代碼

核心代碼

function Game(tr, td, mineNum) { this.td = td; this.tr = tr; this.mineNum = mineNum; //存儲預(yù)設(shè)或設(shè)定的炸彈總數(shù),用于后續(xù)判斷是否勝利使用 this.surplusMine = 0; //剩余雷數(shù) this.mineInfo = []; //用于接收隨機生成的雷的信息 this.tdsArr = [] //存放單元格的信息 this.isPlay = false; //是否開始玩 this.openClass = ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine'] this.gameBox = document.getElementById('gameBox'); this.table = document.createElement('table'); //生成table標簽 this.footerNum = document.getElementById('surplusMine'); //剩余炸彈數(shù)量顯示框 } Game.prototype.creatDom = function() { //創(chuàng)建游戲區(qū)域,在玩家第一次點擊游戲區(qū)域的時候執(zhí)行 this.table.oncontextmenu = function() { return false }; //清除默認右鍵單機事件 for (var i = 0; i < this.gameBox.children.length; i++) { //為防止重新開始游戲時,重復(fù)生成多個table,在添加之前先刪除之前的 var childNod = this.gameBox.children[i]; this.gameBox.removeChild(childNod); } for (var i = 0; i < this.tr; i++) { var tr = document.createElement('tr'); this.tdsArr[i] = []; //為每一行生成一個數(shù)組 for (var j = 0; j < this.td; j++) { var td = document.createElement('td'); tr.appendChild(td); //將生成的td插入到tr中 this.tdsArr[i][j] = td; td.info = { //info屬性包括了單元格的所有信息,很重要 type: 'number', //格子類型,用于判斷是否時炸彈 x: i, //行 y: j, //列 value: 0, //當(dāng)該格子周圍有炸彈時顯示該數(shù)值,生成炸彈的時候會++ isOpen: false, //判斷該單元格是否被打開 isFlag: false //判斷是否有標記flag } } this.table.appendChild(tr); //見tr插入到table中 } this.gameBox.appendChild(this.table); } Game.prototype.creatMine = function(event, target) { //生成炸彈,該方法會在用戶第一次點擊棋盤的時候執(zhí)行一次 var This = this; for (var i = 0; true; i++) { //隨機生成炸彈,生成扎當(dāng)數(shù)與設(shè)定扎當(dāng)書mineNum相同時終止循環(huán) var randomX = Math.floor(Math.random() * this.tr), //隨機生成炸彈的行數(shù) randomY = Math.floor(Math.random() * this.td); //隨機生成炸彈的列數(shù) // console.log(randomX + ' ' + randomY) if (target.info.x != randomX || target.info.y != randomY) { //保證第一次點擊的時候不是炸彈 if (this.tdsArr[randomX][randomY].info.type != 'mine') { //保證每次生成的雷的位置不重復(fù) this.tdsArr[randomX][randomY].info.type = 'mine'; //單元格更改屬性為雷 this.surplusMine++; //生成雷的數(shù)量+1 this.mineInfo.push(this.tdsArr[randomX][randomY]); //將生成的雷的信息存放到this變量中,方便后續(xù)使用 } if (this.surplusMine >= this.mineNum) { //當(dāng)生成的炸彈數(shù)量等于設(shè)定的數(shù)量后跳出循環(huán) break; } } } //為每個炸彈周圍的方格添加數(shù)字 for (var i = 0; i < this.mineInfo.length; i++) { var around = this.getAround(this.mineInfo[i], This); //獲取每個炸彈的周圍方格 // console.log(this.getAround(this.mineInfo[i], This)) for (var j = 0; j < around.length; j++) { //將周圍每個方格的value++ around[j].info.value += 1; } } } Game.prototype.getAround = function(thisCell, This) { //獲取某個方格的周圍非炸彈方格,需要傳遞一個單元格dom元素,Game的this var x = thisCell.info.x, //行 y = thisCell.info.y, //列 result = []; // x-1,y-1 x-1,y x-1,y+1 // x,y-1 x,y x,y+1 // x+1,y-1 x+1y x+1,y+1 for (var j = x - 1; j <= x + 1; j++) { for (var k = y - 1; k <= y + 1; k++) { if ( //游戲區(qū)域的邊界,行數(shù)x和列數(shù)y不能為負數(shù),且不能超過設(shè)定的行數(shù)和列數(shù) j < 0 || k < 0 || j > (This.tr - 1) || k > (This.td - 1) || //同時跳過自身和周邊是雷的方格 This.tdsArr[j][k].info.type == 'mine' || (j == x && k == y) ) { continue; //滿足上述條件是則跳過當(dāng)此循環(huán); } else { result.push(This.tdsArr[j][k]) //將符合的單元格push到result中返回 } } } return result; } Game.prototype.lifeMouse = function(event, target) { //左鍵點擊事件 var This = this; //用變量的方式將Game的this傳遞到函數(shù)中 var noOpen = 0; //沒有被打開的格子數(shù)量 if (!target.info.isFlag) { //表示該必須沒有被右鍵標記才能鼠標左擊 if (target.info.type == 'number') { //是數(shù)字時,則可視化 function getAllZero(target, This) { //遞歸函數(shù) // console.log(target.info) if (target.info.isFlag) { //當(dāng)這個單元格之前有被標記過flag時,則將剩余炸彈數(shù)+1 This.surplusMine += 1; target.info.isFlag = false; //單元格被打開后初始化flag } if (target.info.value == 0) { //等于格子的value等于0的時候 target.className = This.openClass[target.info.value]; //可視化 target.info.isOpen = true; //表示該單元格被打開 var thisAround = This.getAround(target, This); //獲取該單元格周圍的格子信息 for (var i = 0; i < thisAround.length; i++) { // console.log(thisAround[i].info.isOpen) if (!thisAround[i].info.isOpen) { //遞歸的條件,當(dāng)格子的open為true時不執(zhí)行g(shù)etAllZero(thisAround[i], This) //執(zhí)行遞歸 } } } else { target.innerHTML = target.info.value; target.className = This.openClass[target.info.value]; //可視化 target.info.isOpen = true; //表示單元格被打開 target.info.isFlag = false; //單元格被打開后初始化flag } } getAllZero(target, This); //首次執(zhí)行 //每次鼠標左鍵點擊的時候都需要檢查一下沒有被打開的方格數(shù)量,每有一個則noOpen++ for (var i = 0; i < this.tr; i++) { for (var j = 0; j < this.tr; j++) { if (this.tdsArr[i][j].info.isOpen == false) { noOpen++; } } } //當(dāng)noOpen的數(shù)量與炸彈數(shù)量相同時,說明剩余的方格全是雷,游戲通過 if (noOpen == this.mineNum) { console.log(noOpen) this.gameWin(); } } else { //點擊到了炸彈,游戲結(jié)束 this.gameOver(target) } } } Game.prototype.rightMouse = function(target) { //鼠標右鍵點擊執(zhí)行 if (!target.info.isOpen) { if (!target.info.isFlag) { //標記 target.className = 'targetFlag'; //顯示旗幟 target.info.isFlag = true; //表示該方格已經(jīng)被標記 this.surplusMine -= 1; //每標記一個方格,剩余炸彈數(shù)量-=1 // console.log(this.surplusMine) } else { //取消標記 target.className = ''; //去掉旗幟 target.info.isFlag = false; this.surplusMine += 1; // console.log(this.surplusMine) } var isWin = true; if (this.surplusMine == 0) { //標記完所有flag時,遍歷所有單元格 // console.log(this.mineInfo.length) for (var i = 0; i < this.mineInfo.length; i++) { console.log(this.mineInfo[i].info.isFlag) if (!this.mineInfo[i].info.isFlag) { //檢查每個雷的isFlag屬性是否被標記,只要有一個為false則輸?shù)粲螒? isWin = false; this.gameOver(target, 1); break; } } isWin ? this.gameWin(1) : 0; //三目運算符號 } // if (this.surplusMine == 0) { //標記完所有flag時,遍歷所有單元格 // for (var i; i < this.tr; i++) { // for (var j; j < this.td; j++) { // if() // } // } // } } } Game.prototype.gameOver = function(target, code) { //游戲結(jié)束,code為觸發(fā)代碼,當(dāng)旗用完了時為1,點擊到炸彈為0 // console.log(this.mineInfo) var mineInfoLen = this.mineInfo.length; for (var i = 0; i < mineInfoLen; i++) { //顯示每個雷的位置 this.mineInfo[i].className = 'mine'; } this.table.onmousedown = false; //取消鼠標事件 if (code) { alert('旗幟用完了,沒有排除所有雷,游戲結(jié)束') } else { target.className = 'targetMine'; //觸發(fā)雷標紅色 alert('你被炸彈炸死了,游戲結(jié)束') } } Game.prototype.gameWin = function(code) { //游戲勝利 if (code) { alert('你成功標記所有地雷,游戲通過') } else { alert('你找到了所有安全區(qū)域,游戲通過') } this.table.onmousedown = false; } Game.prototype.play = function() { var This = this; //需要將this傳遞到事件函數(shù)中使用 this.table.onmousedown = function(event) { event = event || window.event; //兼容IE target = event.target || event.srcElement //兼容IE if (!this.isPlay) { //首次點擊初始化棋盤,隨機生成炸彈 this.isPlay = true; This.creatMine(event, target); } if (event.button == 0) { //鼠標左鍵點擊時執(zhí)行 This.lifeMouse(event, target); } else if (event.button == 2) { //右鍵點擊執(zhí)行 This.rightMouse(target) } This.footerNum.innerHTML = This.surplusMine; //每次點擊右鍵,刷新頁面下方的剩余雷數(shù) } } Game.prototype.tablePos = function() { //將table居中顯示 var width = this.table.offsetWidth, height = this.table.offsetHeight; // console.log(this.table.offsetWidth) this.table.style.width = width + 'px '; this.table.style.height = height + 'px ' } function addEvent(elem, type, handle) { //添加事件函數(shù) if (elem.addEventListener) { //w3c標準 elem.addEventListener(type, handle, false); } else if (elem.attachEvent) { //IE9及以下 elem.attachEvent('on' + type, function() { handle.call(elem); }) } else { //其他情況 elem['on' + type] = handle; } } Game.prototype.setDegree = function() { //調(diào)整難度 var button = document.getElementsByTagName('button'); addEvent(button[0], 'click', function() { //簡單 var game = new Game(10, 10, 10); game.creatDom(); game.play(); game.tablePos(); }); addEvent(button[1], 'click', function() { //一般 var game = new Game(16, 16, 50); game.creatDom(); game.play(); game.tablePos(); }); addEvent(button[2], 'click', function() { //困難 var game = new Game(30, 30, 125); game.creatDom(); game.play(); game.tablePos(); }); } // 默認棋盤 var game = new Game(10, 10, 10); game.creatDom(); game.play(); game.tablePos(); game.setDegree()

總結(jié)一下,該游戲個人覺得難點有4個:

沒有思路,在bilibili看了一個教學(xué)視頻,但是比較難理解,在原有基礎(chǔ)上增加了自己的一些想法 遞歸 獲取某一個方格周圍的八個方格 多層的if嵌套和循環(huán)

缺點:

性能不佳,存在大量for循環(huán),且沒有優(yōu)化 某些時候界面顯示的剩余炸彈數(shù)量不準確(已修復(fù)) 代碼冗余較多

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 免费 视频 1级 | 自拍第一页 | 国产区最新 | 台湾av在线 | 日本在线小视频 | 欧美a在线看 | 思九九爱九九 | 日韩三区 | 色婷婷av一区二区三区大白胸 | 国产免费黄色大片 | 国产福利视频 | 蜜桃av一区二区三区 | 精品国产髙清在线看国产毛片 | 欧美激情a∨在线视频播放 中文字幕网在线 | 亚洲精品一区国产精品 | 久久亚洲网 | 国产91精品一区二区绿帽 | 免费一区二区三区视频在线 | 成人网久久| 三级成人在线 | 天天干狠狠干 | 成人免费大片黄在线播放 | 国产亚洲一区二区三区在线观看 | 亚洲成熟少妇视频在线观看 | 日本黄色免费大片 | 成人免费影院 | 一级片免费视频 | 一区在线视频 | 久久成人国产视频 | 国产成人片 | 久久99精品一区二区三区三区 | 久久久在线视频 | 国产在线精品一区二区三区 | 欧美日韩在线观看一区二区三区 | 日本妇人成熟免费视频 | 亚洲成人一区二区 | eeuss国产一区二区三区四区 | 久久久影视 | 国产大学生一区 | 中文字幕成人av | 日韩欧美在线视频播放 | 青青草一区二区三区 | 久久国产综合 | 亚洲精品综合中文字幕 | 日韩欧美高清dvd碟片 | 亚洲精品一区在线观看 | 在线欧美日韩 | 久久国产经典视频 | 国产视频第一区 | 国产视频一区在线 | 国产精品久久久久久久久久大牛 | 久国产精品 | 国产精品久久久久久久久久久久久 | 日韩在线不卡 | 日韩欧美在线视频 | 久国久产久精永久网页 | 一级毛片免费视频 | 精品免费视频 | 98精品国产高清在线xxxx天堂 | www.日本三级 | 成人精品久久久 | 99久久综合 | 人人干在线 | 国产xxxx成人精品免费视频频 | 国产精品网站在线观看 | 亚洲欧美综合精品久久成人 | 久久爱综合网 | 国产精品久久久麻豆 | 日韩激情视频一区二区 | 久久久久国产视频 | 成人av入口 | 久久久久久久久99精品 | 国产精品视频一区二区免费不卡 | 国产精品久久久久久久久 | 亚洲国产精品一区二区第一页 | 天堂中文资源在线 | 精品久久久久久国产 | 久久久国产一区二区 | 热re99久久精品国产99热 | 百性阁综合另类 | 日韩精品在线视频观看 | 免费成人在线观看 | 91xx在线观看 | 成人激情在线 | 国产一级视频免费播放 | 亚洲精品视频国产 | 国产精品综合 | 成人精品免费视频 | 日韩精品免费观看 | 狠狠躁夜夜躁人人爽视频 | 麻豆专区一区二区三区四区五区 | 国产一级免费在线 | 日本视频一区二区三区 | 在线播放三级 | 在线免费看黄视频 | 成全视频免费观看在线看黑人 | 色欧美综合 | 欧美极品欧美精品欧美视频 | 亚洲av毛片一区二二区三三区 | 欧美国产日韩一区 | 亚洲欧洲日韩在线 | 欧美日韩亚洲视频 | 中文字幕日韩一区二区三区 | 午夜国产 | 91一区二区三区久久国产乱 | 在线99热 | 亚洲女人天堂成人av在线 | 久久免费精品视频 | 欧美亚洲视频在线观看 | 成年免费观看视频 | 在线观看91 | 毛片91| 久久com | 欧美国产精品一区二区 | 午夜欧美一区二区三区在线播放 | 91精品国产一区二区三区香蕉 | 狠狠干天天干 | 久草视频免费看 | 很黄很色很爽的视频 | 亚洲精品成人 | 日本视频一区二区三区 | 日韩电影a | 老司机午夜免费精品视频 | 欧美五月婷婷 | 国产精品国产三级国产aⅴ中文 | 成人av网站在线 | 欧美一区二区三区精品 | 大陆一级毛片免费视频观看 | 国产精品久久久 | 国产91成人在在线播放 | 激情欧美一区 | 国产精品一区二区视频 | 成人欧美一区二区三区在线播放 | 国产一区久久精品 | 精品视频在线免费观看 | 国产二区三区 | 亚洲日本欧美日韩高观看 | 国产高清美女一级a毛片久久 | 亚洲综合国产 | 97碰碰碰 | 亚州精品视频 | 欧美日韩在线一区二区 | 国产精品久久久久久久一区探花 | 日韩免费福利视频 | 日韩成人在线播放 | 亚洲国产精品久久久久秋霞不卡 | 成人av网站免费观看 | 国产综合亚洲精品一区二 | 日韩一区二区在线观看 | 国产激情亚洲 | 欧美在线亚洲 | 作爱视频免费看 | 国产婷婷综合 | 国产精品对白一区二区三区 | 韩日视频在线观看 | 操操操操操操操操操操操操操操 | 伊人久久精品久久亚洲一区 | 国产农村妇女精品久久 | 国产亚洲视频在线 | 欧美性生活视频 | 北条麻妃一区二区三区中文字幕 | 久久人人爽人人爽人人片av高清 | 国产91一区 | 日日干夜夜骑 | 精品久久久久久久久久久久久久 | 五月婷婷综合久久 | 欧美综合一区 | 羞羞在线观看视频免费观看hd | 久久精品无码一区二区三区 | 欧美成人猛片aaaaaaa | 日本a视频| 欧美五月| 久久小视频 | 成人精品一区二区三区 | 亚洲免费视频网站 | 国产精品免费一区二区三区四区 | 国产在线高清 | 久久午夜影院 | 97国产在线视频 | 狠狠爱天天干 | 91综合在线观看 | 国产成人综合一区二区三区 | 三级无遮挡污在线观看 | www.久久.com | 国产传媒自拍 | 欧美日韩一区二区三区在线观看 | www.日本三级 | 99精品一区二区三区 | 亚洲污视频 | 午夜激情在线观看 | 99国产精品久久久久久久 | 午夜视频在线观看网站 | 日韩一区二区在线电影 | 韩国av一区二区 | 波多野结衣福利电影 | 婷婷激情综合 | 成人av观看| 日韩欧美三区 | 日韩欧美在线看 | 91亚洲精品乱码久久久久久蜜桃 | 欧美日韩成人在线视频 | 日韩在线观看第一页 | 91精品久久久久久久久 | 日韩精品一区二区三区第95 | 精品日韩一区二区 | 久久久久久久久久一区二区 | 中文字幕精品一区 | www中文字幕在线观看 | 天堂资源在线 | 性色网站| 久久综合一区二区三区 | 国产精品国产三级国产aⅴ原创 | 四虎影院免费看 | 一级毛片免费网站 | 日日夜夜精品网站 | 免费看的毛片 | 国产一区在线看 | 国产精品成人国产乱一区 | 五月激情综合 | 91影院在线观看 | 国产视频二区 | 色婷婷网 | 91高清视频 | 看特级毛片| 成人在线免费视频 | 欧美极品一区二区 | 麻豆精品国产传媒 | 国产成年免费视频 | 久久综合久色欧美综合狠狠 | 黄色高清视频在线观看 | 91国内精品久久 | 成人免费视频网 | 狠狠操狠狠操 | av在线成人 | 青青草在线视频免费观看 | 天天干欧美 | 成人黄色免费 | 国产高清精品一区二区三区 | 噜噜噜天天躁狠狠躁夜夜精品 | 在线观看视频一区二区 | 欧洲精品视频一区 | 日韩中文在线视频 | 一区二区三区免费在线观看 | 粉嫩国产精品一区二区在线观看 | av在线播放免费 | 成人免费在线视频观看 | 国产区视频在线观看 | 在线观看v片 | 91精品国产色综合久久 | 欧美日韩成人在线视频 | 看毛片网站 | 欧美一级黄色大片 | 一区二区免费在线 | 欧美99 | 97人人草| 一级片在线观看免费 | 中字精品 | 色婷婷在线视频 | 99精品欧美一区二区蜜桃免费 | 日韩免费精品 | 欧美日韩另类在线 | 在线观看欧美一区二区三区 | 青楼18春一级毛片 | 久久久久成人精品 | 综合久久99 | 久久理论片 | 超碰国产一区 | 日韩午夜免费 | 免费av一区二区三区 | 国产96在线观看 | 成人片网址 | 午夜国产精品成人 | 一区久久| 国产羞羞视频在线观看 | 国产精品久久久久久亚洲调教 | 国产精品www | 国产成人一区二区三区 | 国产精品二区三区 | 午夜激情免费看 | 亚洲免费在线观看 | 福利网址 | 国产精品一区久久久 | 91视在线国内在线播放酒店 | 狠狠亚洲| 成人亚洲 | 久久久久成人精品 | 91传媒在线播放 | 亚洲中午字幕 | 久久视频免费 | 99在线精品视频 | 中文字幕在线看 | 国产一区二区精品 | 久久xxx| 国产成人免费视频网站视频社区 | 久久99国产精品 | 日韩城人网站 | 一区二区国产精品 | 久操综合 | 91麻豆精品国产91久久久久久 | 国产精品二区三区 | 无毒黄网 | 婷婷激情五月 | 九九久久国产 | 国产精品看片 | 成人黄色片网站 | 一级成人免费 | 亚洲欧美一区二区三区不卡 | 国产成人精品久久二区二区91 | 偷派自拍| av在线天堂 | 国产在线综合视频 | aaaaaaa片毛片免费观看 | 国产精品久久久久久一区二区三区 | 国产精品久久久久久久免费大片 | 国产精品一区2区 | 午夜视频网 | av成人在线观看 | 久久美女视频 | 一区二区三区四区 | 国产特级毛片aaaaaa毛片 | 亚洲欧洲免费视频 | 91一区二区在线 | 精品国产一区二区三区在线观看 | 亚洲欧美日韩另类精品一区二区三区 | 人人草人人 | 亚洲欧美一区二区在线观看 | 国产在线激情视频 | 青青草视频网站 | 日韩精品1区2区 | 在线看国产 | 亚洲www啪成人一区二区 | 精品一区二区三区四区视频 | 影音先锋国产 | 在线视频自拍 | 久久ri资源网 | 亚洲一区二区三区免费在线观看 | 亚洲v欧美| 成人黄色一级片 | 国产午夜精品一区二区三区嫩草 | 久久999视频| 日韩成人影院 | 自拍偷拍在线视频 | 国产一二三区在线观看 | 日韩一区二区精品视频 | 国产影音先锋 | 亚洲精品一区二区三区在线观看 | 日本精品免费 | 高清av网站 | www日本视频 | 国产日韩欧美 | 春色导航 | 成人网在线观看 | 人和拘一级毛片 | 国内精品国产三级国产在线专 | 亚洲www视频 | 久久久日韩精品一区二区三区 | 久久一区二区三区四区五区 | 中文字幕爱爱视频 | 午夜影院在线 | 亚洲第一男人天堂 | 日本高清视频在线播放 | 久久综合狠狠综合久久综合88 | 久久9999久久 | 亚洲一区播放 | 在线观看免费av网 | 亚洲人成在线播放 | 日本一区二区不卡视频 | 日韩成人小视频 | 麻豆freexxxx性91精品 | 日本在线观看一区二区 | 亚洲日本乱码一区两区在线观看 | 欧美日韩毛片 | 国产亚洲精品久久久优势 | 精品国产欧美一区二区三区成人 | 午夜精品久久久久99蜜 | 亚州综合 | 亚洲视频在线观看免费 | 99精品免费 | 色花av | 精品国产欧美一区二区 | av成人一区二区 | 天天躁人人躁人人躁狂躁 | 色综合天天天天做夜夜夜夜做 | 91久久久www播放日本观看 | 91视频在线观看 | 久久国内精品 | 成人在线视频一区 | 一道本一区二区三区 | 成人免费淫片aa视频免费 | 97天堂 | 国产综合久久 | 精品亚洲一区二区三区 | 伊人免费视频二 | 日本精品免费在线观看 | 男人久久天堂 | 91九色视频在线 | 日韩中文字幕在线观看 | 久久久一 | 狠狠狠色丁香婷婷综合久久五月 | 国产美女高潮一区二区三区 | 国产亚洲网站 | 综合二区 | 天天艹逼 | 波多野结衣一区二区三区四区 | 欧美日韩亚洲一区二区 | 深夜福利亚洲 | 一二三区在线 | 久久av一区二区三区 | 亚洲精品久久久久久一区二区 | 亚洲精品一区二区三区蜜桃下载 | 久久婷婷麻豆国产91天堂 | 一区二区三区国产好 | 91精品国产综合久久久久久丝袜 | 91免费网| 99精品久久精品一区二区爱城 | 国产精品99久久久久久www | 一区二区不卡视频在线观看 | 精品无码久久久久久国产 | 精品亚洲一区二区三区 | 国产精品一区二区三区在线 | 在线精品观看 | 三级av网站 | 中文字幕国产一区 | 亚洲一区中文字幕在线观看 | 欧洲精品久久久 | 亚州av | 成人影院欧美黄色 | 97精品超碰一区二区三区 | 综合激情久久 | 日本a v在线播放 | 午夜私人影院 | 日韩精品一区二区三区四区视频 | 手机在线观看av | 国产精品国产精品国产专区不卡 | 91在线视频观看 | 久久国产精品免费一区二区三区 | 亚洲人成人一区二区在线观看 | 成人免费看电影 | 91免费小视频| 久久国产精品免费一区二区三区 | 99精品一区二区 | 亚洲自拍偷拍精品 | 男人的天堂久久 | 日本一区二区不卡 | 精品久久网 | 一级电影在线观看 | 亚洲精品一区二区三区精华液 | 九九热精品视频 | 91精品国产91久久久久久 | 天堂一区二区三区四区 | 视频精品一区二区三区 | 亚洲毛片 | 蜜臀91精品国产高清在线观看 | 女人久久久久久久 | 国产成人精品电影 | 成人免费在线电影 | 久久精品电影 | 国产成人一级片 | 超碰天天 | 国产视频精品视频 | 日韩高清在线一区 | 欧美一级一区 | 天天干天天操 | 欧美日韩国产中文 | 久久久久久久久久久精 | 亚洲国产一区二区三区在线观看 | 国产在线一区二区三区 | 久久夜视频 | 一色屋精品久久久久久久久久 | 久久久久久久久久久久网站 | 超碰伊人网 | 成人欧美一区二区三区白人 | 午夜性电影 | 七龙珠z普通话国语版在线观看 | av在线免费观看一区二区 | 久久精品欧美一区二区三区不卡 | 国产精品久久久一区二区 | 国产免费视频 | 韩国精品一区二区 | 精品国产一区二区三区在线观看 | 亚洲精品一区二三区不卡 | 国产剧情一区二区 | 婷婷亚洲综合 | 欧美一区久久 | 九九热精品视频在线观看 | 亚洲国产婷婷香蕉久久久久久99 | 亚洲一区二区三区免费在线观看 | 欧美日韩精品免费观看视频 | 久久婷婷色 | a级毛片免费高清视频 | 亚洲成人久久久 | 久久www免费视频 | 久久久999精品视频 欧美老妇交乱视频 | 国产精品手机在线 | 国产精品色婷婷亚洲综合看 | 日韩亚洲视频在线观看 | av天天网 | 日本成人福利视频 | 一区二区三区四区在线 | 天天干天天干天天干天天射 | 久久久精品一区二区三区 | 天天干天天操天天爽 | 精品一区二区三区免费毛片 | 黄色一级毛片 | 中文字幕日韩欧美一区二区三区 | 亚洲国产精品一区二区三区 | 亚洲精品美女久久久 | av网站在线免费观看 | 成人一级片 | 国产精品久久久久久久久久久新郎 | 91精品国产九九九久久久亚洲 | 五月天婷婷激情视频 | 亚洲一区不卡在线 | 欧美视频在线一区 | 91亚洲国产成人久久精品网站 | 国内精品久久久久久中文字幕 | 久久国 | 国产精品一二区 | 亚洲美女网站 | 午夜免费| 日韩91| 亚洲午夜精品 | 91精品国产色综合久久 | 99久久久久久 | 男女羞羞视频免费看 | 欧美性猛片 | 国产极品探花 | 久久兔费看a级 | 黄色片免费观看 | 91亚洲国产成人精品性色 | 高清精品一区二区 | 国产一区二区在线免费观看 | 精品国产一区二区国模嫣然 | 亚洲综合无码一区二区 | 日韩欧美视频一区 | 涩久久| 日本久久免费 | 日本中文字幕电影 | 视频一区久久 | 欧美日韩电影一区二区三区 | a久久久久久 | 成人av一区二区三区 | 91视频国产网站 | 奇米成人影视 | 黄色高清视频 | 国产区视频在线观看 | 在线免费黄色小视频 | 日韩最新网址 | 成人av一区二区三区 | 国产一级免费在线观看 | 玖草av| 国产在线一二三区 | 一级免费在线视频 | 91九色在线观看 | 欧美精品一区二区三区中文字幕 | 97视频久久 | 日韩不卡一区二区 | 性色av一区二区三区免费看开蚌 | 久久久久久毛片免费播放 | 国产精品成人在线观看 | 永久av| 亚洲蜜臀av乱码久久精品蜜桃 | 91资源在线 | 国产区久久 | 乱人伦xxxx国语对白 | 欧美日韩中文 | 日韩91| 国精品产品区三区 | 天堂va| 国产精品a久久久久 | 91.成人天堂一区 | 久久二区三区 | 五月激情综合网 | 精品国产天堂 | 草草久久久 | 国产精品一区二区三区免费视频 | 性色视频免费观看 | 精品国产91 | 久久av一区 | 国产区视频 | 成人欧美一区二区三区白人 | 国产日韩精品在线观看 | 亚洲视频精品一区 | 久久久久久久免费 | 91国内精品久久 | 在线看片网站 | 免费在线观看一级毛片 | 精品久久精品 | 狠狠操狠狠操 | 久草视频在线播放 | 男女免费视频 | 日韩一区二区三区在线视频 | 亚洲一级淫片 | 亚洲精品网址 | 亚洲精品久久 | 国产精品影院在线观看 | 三级av网站 | 91九色视频在线 | 天天看天天摸天天操 | 国产日韩一区二区 | 精品伦理一区二区三区 | 亚洲蜜臀av乱码久久精品蜜桃 | 毛片一区 | 91精品一区二区三区久久久久久 | 特一级毛片| av免费看在线 | 国产成人欧美一区二区三区的 | 91精品国产综合久久久久久蜜月 | 国产成人一区 | 午夜视频网| 国内自拍视频网 | 亚洲精品一区二区三区蜜桃下载 | 欧美a视频 | 在线观看国产日韩欧美 | 91精品国产综合久久久蜜臀粉嫩 |