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

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

vue開發(fā)chrome插件,實現(xiàn)獲取界面數(shù)據(jù)和保存到數(shù)據(jù)庫功能

瀏覽:222日期:2022-10-22 13:15:05

前言

最近在評估項目時,要開啟評估平臺,查看平臺和保存平臺,感覺非常繁瑣,開發(fā)了一款可以獲取評估平臺數(shù)據(jù),查看項目排期和直接保存數(shù)據(jù)到數(shù)據(jù)庫的chrome插件,由于我需要使用之前vue封裝的一個日歷插件,這里就用vue來開發(fā)這個插件。

開發(fā)前準備

要開發(fā)一個chrome插件,我們首先需要了解chrome插件的基本結(jié)構和對應的功能。每個擴展的文件類型和目錄數(shù)量有所不同,但都必須有 manifest。 一些基本但有用的擴展程序可能僅由 manifest 及其工具欄圖標組成。

manifest.json

{ 'name': 'My Extension', // '擴展名' 'version': '2.1', // 當前創(chuàng)建擴展版本號 'description': 'Gets information from Google.', //'擴展描述' 'icons': { // 擴展工具界面使用圖標 '128': 'icon_16.png', '128': 'icon_32.png', '128': 'icon_48.png', '128': 'icon_128.png' }, 'background': { // 擴展常常用一個單獨的長時間運行的腳本來管理一些任務或者狀態(tài) 'persistent': false, 'scripts': ['background_script.js'] // 后臺常駐腳本,自動運行,直到關閉瀏覽器。可根據(jù)需求自行設置 }, 'permissions': ['https://*.google.com/', 'activeTab'], //開啟拓展權限 'browser_action': { 'default_icon': 'icon_16.png', // 器右上角顯示 'default_popup': 'popup.html' /** 鼠標移入,顯示簡短擴展文本描述 **/ }, 'content_scripts': [{ // ontent scripts是在Web頁面內(nèi)運行的javascript腳本。通過使用標準的DOM,它們可以獲取瀏覽器所訪問頁面的詳細信息,并可以修改這些信息。 'js': ['script/contentscript.js'], /** 需要注入的腳本 **/ 'matches': [ /** 匹配網(wǎng)址(支持正則),成功即注入(其余屬性自行查詢) **/ 'http://*/*', 'https://*/*' ] }] }

vue開發(fā)chrome插件

我們需要使用vue來開發(fā)插件,幾經(jīng)搜索,查到一款樣板,很方便我們進行vue開發(fā)插件,便引入該樣板來進行開發(fā)。

引入vue-web-extension樣板來實現(xiàn)vue開發(fā)

npm install -g @vue/cli npm install -g @vue/cli-init vue init kocal/vue-web-extension new-tab-page

然后切換到項目目錄安裝依賴項

cd new-tab-page npm install

我們可以運行

npm run watch:dev

在項目根目錄中會得到一個dist 文件夾,我們直接安裝解壓的擴展程序,選擇這個dist,就可以進行開發(fā)并監(jiān)視更改。

樣板文件的基本格式

├── dist│ └── <the built extension>├── node_modules│ └── <one or two files and folders>├── package.json├── package-lock.json├── scripts│ ├── build-zip.js│ └── remove-evals.js├── src│ ├── background.js│ ├── icons│ │ ├── icon_128.png│ │ ├── icon_48.png│ │ └── icon.xcf│ ├── manifest.json│ └── popup│ ├── App.vue│ ├── popup.html│ └── popup.js└── webpack.config.js

可以看出,樣板文件使用 webpack進行打包,

src文件夾包含我們將用于擴展的所有文件。manifest 文件和 background.js 對于我們來說是熟悉的,但也要注意包含Vue 組件的 popup 文件夾。當樣板文件將擴展構建到 dist 文件夾中時,它將通過vue-loader 管理所有 .vue 文件并輸出一個瀏覽器可以理解的 JavaScript 包。

在 src 文件夾中還有一個 icons 文件夾。如果你看一眼 Chrome 的工具欄,會看到我們的擴展程序的新圖標(也被稱為 browser action)。這就是從此文件夾中拿到的。如果單擊它,你應該會看到一個彈出窗口,顯示“Hello world!” 這是由 popup/App.vue 創(chuàng)建的。

最后,請注 scripts 文件夾的兩個腳本:一個用于刪除 eval 用法以符合 Chrome Web Store 的內(nèi)容安全策略,另一個用于當你要把擴展上傳到Chrome Web Store時將其打包到 .zip 文件中。

在 package.json 文件中還聲明了各種腳本。我們將用 npm run watch:dev 來開發(fā)擴展,然后使用 npm run build-zip 生成一個ZIP文件以上傳到 Chrome Web Store。

創(chuàng)建插件界面

我們直接修改popup.html

popup.html

<!DOCTYPE html><html lang='zh'><head> <meta charset='UTF-8'> <title>Title</title></head><body> <link href='http://www.gepszalag.com/bcjs/popup.css' rel='external nofollow' rel='stylesheet'> <div id='app'> </div> <script src='http://www.gepszalag.com/bcjs/popup.js'></script></body></html>

這里我們引入popup.css和popup.js 在popup.css放入我們需要用的樣式 在popup.js中,來引入我們的vue文件

popup.js

import Vue from ’vue’ import { Tabs,TabPane, Dialog, Button,Form,FormItem,Input,DatePicker,Message,Alert,Tooltip,MessageBox } from ’element-ui’; import ’element-ui/lib/theme-chalk/index.css’; import App from ’./App’ Vue.use(Tabs); Vue.use(TabPane); Vue.use(Dialog); Vue.use(Button); Vue.use(Form); Vue.use(FormItem); Vue.use(Input); Vue.use(DatePicker); Vue.use(Tooltip); Vue.use(Alert); Vue.prototype.$message = Message; Vue.prototype.$confirm = MessageBox.confirm; new Vue({ el: ’#app’, render: h => h(App) })

這里,我們主要按需引入element-ui中的控件,和app.vue組件

app.vue

<template> <div style='height: 580px;overflow-y: hidden;width:680px;'> <div> 模板 </div> <customPlan :projectData='projectData' :loginPerson='loginPerson'></customPlan> </div></template><script>import customPlan from ’../components/customPlan’let { Pinyin } = require(’../script/pinyin’)let pinyin = new Pinyin()export default { components: { customPlan }, data() { return { loginPerson: ’’, projectData: { departmentName: ’’, developer: ’’, endDate: ’’, evaluator: ’’, isDeprecated: false, isIncludeSaturday: false, isNewComponent: false, issureAdress: ’’, msg: ’’, name: ’’, startDate: ’’, workDay: ’’, year: 2020 } } }, created() { this.getUrl() }, methods: { getCaption(obj) { var index = obj.lastIndexOf(’,’) obj = obj.substring(index + 1, obj.length) return obj }, /** * @desc 獲取當前頁面的url */ getUrl() { chrome.tabs.getSelected(null, tab => { console.log(tab,'tab') this.projectData.issureAdress = tab.url chrome.tabs.sendMessage(tab.id, { greet: ’hello’ }, response => { if (response && response.developer && response.processName) { let developer = pinyin .getFullChars(this.getCaption(response.developer)) .toLowerCase() this.projectData.evaluator = developer this.projectData.name = response.processName } else if (response && response.developer && !response.processName) { var index = response.developer.lastIndexOf(’@’) response.developer = response.developer.substring( index + 1, response.developer.length ) this.loginPerson = response.loginPerson this.projectData.evaluator = response.developer this.projectData.name =response.peocessName } }) }) } }}</script>

在manifest.json中引入

'browser_action': { 'default_title': '測試', 'default_popup': 'popup/popup.html' },

這里我們主要引入了我們的日歷控件customPlan,大家可以按需引入自己需要的組件。到這里,我們的插件界面基本搭建完成了。

獲取當前界面數(shù)據(jù),并在插件中進行監(jiān)聽

需要獲取當前界面數(shù)據(jù),就需要在Web頁面內(nèi)運行的javascript腳本。通過使用標準的DOM,它們可以獲取瀏覽器所訪問頁面的詳細信息,并可以修改這些信息。就需要content_scripts里面引入我們需要的contentscript.js文件,在這個js文件中,可以獲取瀏覽器所訪問頁面的詳細信息

'content_scripts': [{ 'js': ['script/contentscript.js'], 'matches': [ 'http://*/*', 'https://*/*' ] }]

contentscript.js文件配置如下

document.addEventListener(’click’, function (e) { let isCurrect = e.path.length > 3&&e.path[4].innerText&&e.path[4].innerText.indexOf(’提交需求’) != -1 && e.target.innerText === ’確 定’ && document.getElementsByClassName(’layout-nav’) && document.getElementsByClassName(’layout-nav’)[0].children if (isCurrect) { if (document.getElementsByClassName(’user-table’) && document.getElementsByClassName(’user-table’)[0] && document.getElementsByClassName(’user-table’)[0].getElementsByClassName(’el-table__row’).length > 0) { var port = chrome.runtime.connect({ name: 'custommanage' });//通道名稱 let loginPerson = document.getElementsByClassName(’layout-nav’) && document.getElementsByClassName(’layout-nav’)[0].children ? document.getElementsByClassName(’layout-nav’)[0].children[0].innerText : ’’ let partMentName = document.getElementsByClassName(’layout-nav’) && document.getElementsByClassName(’layout-nav’)[0].children ? document.getElementsByClassName(’layout-nav’)[0].children[3].innerText : ’’ let processName = document.getElementsByClassName(’el-input__inner’) && document.getElementsByClassName(’layout-nav’)[0].children ? document.getElementsByClassName(’el-input__inner’)[0].title : ’’ let tableElement = document.getElementsByClassName(’user-table’) ? document.getElementsByClassName(’user-table’)[0].getElementsByClassName(’el-table__row’) : [] let choseSelect = [] for (let value of tableElement) {if (value.innerText.indexOf(partMentName) !== -1) { choseSelect = value} } let developPerson = ’’ let startTime = ’’ let endTime = ’’ if (choseSelect && choseSelect.getElementsByTagName(’td’)) {developPerson = choseSelect.getElementsByTagName(’td’)[1].innerTextstartTime = choseSelect.getElementsByTagName(’td’)[3].getElementsByTagName(’input’)[0].titleendTime = choseSelect.getElementsByTagName(’td’)[4].getElementsByTagName(’input’)[0].title } let item = {'loginPerson': loginPerson,'processName': processName,'developPerson': developPerson,'startTime': startTime,'endTime': endTime } port.postMessage(item);//發(fā)送消息 } else { alert(’未查到該項目預排人員與預排時間,請點開插件或打開定制管理系統(tǒng)手動添加項目!’) } }});

這里獲取元素就是js基本知識了。主要使用chrome插件的api

chrome.runtime.connect

保持長期連接的模式,在content scripts與Chrome擴展程序頁面之間建立通道(可以為通道命名),可以處理多個消息。在通道的兩端分別擁有一個chrome.runtime.Port對象,用以收發(fā)消息。這里主要在我們點擊需要的按鈕時,就會向chrome插件發(fā)送消息。在content scripts主動建立通道如下:

var port = chrome.runtime.connect({name: 'custommanage'});//通道名稱 port.postMessage({joke: 'Knock knock'});//發(fā)送消息 port.onMessage.addListener(function(msg) {//監(jiān)聽消息 port.postMessage({answer: 'custommanage'}); });

獲取到界面信息后,在content scripts發(fā)生請求消息給Google Chrome擴展程序,我們在插件中就需要獲取獲取的界面信息了

chrome擴展獲取信息

我們在background.js中建立通道,獲取web界面?zhèn)骰氐男畔?/p>

chrome.tabs.query( { active: true, currentWindow: true }, function (tabs) { var port = chrome.tabs.connect(//建立通道 tabs[0].id, { name: 'custommanage' }//通道名稱 ); });chrome.runtime.onConnect.addListener((port) => { console.assert(port.name == 'custommanage'); port.onMessage.addListener((res) => { addActon(res) });});

addAction函數(shù)即是保存我們獲取的數(shù)據(jù)到數(shù)據(jù)庫。

/** * @desc 添加獲取數(shù)據(jù)到數(shù)據(jù)庫 */function addProject (params) { let paramsObj = Object.assign({}, params) let optsUpdata = { method: ’POST’, //請求方法 body: JSON.stringify(paramsObj), //請求體 headers: { Accept: ’application/json’, ’Content-Type’: ’application/json’ } } fetch(’http://****/api/EditConfirmWork’, optsUpdata) .then(response => { return response.json() }) .then(data => { if (data.code === 0) { alert(’更新成功!’) } }) .catch(error => { alert(error) })}

這里我們采用fetch函數(shù)來連接數(shù)據(jù)庫,和修改數(shù)據(jù)庫,后端接口也需要做一些跨域相關處理,才能正常連接,我這里用的Node開發(fā)的后端,大致代碼如下

//跨域app.all(’*’, function (req, res, next) { res.header('Access-Control-Allow-Origin', '*'); res.header(’Access-Control-Allow-Methods’, ’PUT, GET, POST, DELETE, OPTIONS’); res.header(’Access-Control-Allow-Headers’, ’Origin, X-Requested-With, Content-Type, Accept’); res.header(’Access-Control-Allow-Credentials’, true) next();});

到此,獲取界面數(shù)據(jù),并自動保存到數(shù)據(jù)庫功能已完成,background.js我們在manifest.json引用下。

'background': { 'scripts': ['script/background.js'] },

我們需要將編輯好的插件通過webpack打包,還需要在webpack.config.js配置一下,然后運行npm run watch:dev 就可以得到我們需要的dist,安裝到擴展程序就可使用了。

webpack.config.js配置如下

const webpack = require(’webpack’);const ejs = require(’ejs’);const MiniCssExtractPlugin = require(’mini-css-extract-plugin’);const WebpackShellPlugin = require(’webpack-shell-plugin’);const CopyWebpackPlugin = require(’copy-webpack-plugin’);const ChromeExtensionReloader = require(’webpack-chrome-extension-reloader’);const { VueLoaderPlugin } = require(’vue-loader’);const { version } = require(’./package.json’);const config = { mode: process.env.NODE_ENV, context: __dirname + ’/src’, entry: { ’popup/popup’: ’./popup/popup.js’, ’script/contentscript’: ’./script/contentscript.js’, ’script/background’: ’./script/background.js’ }, output: { path: __dirname + ’/dist’, filename: ’[name].js’, }, resolve: { extensions: [’.js’, ’.vue’], }, module: { rules: [ { test: /.vue$/, loaders: ’vue-loader’, }, { test: /.js$/, loader: ’babel-loader’, exclude: /node_modules/, }, { test: /.css$/, use: [MiniCssExtractPlugin.loader, ’css-loader’], }, { test: /.scss$/, use: [MiniCssExtractPlugin.loader, ’css-loader’, ’sass-loader’], }, { test: /.sass$/, use: [MiniCssExtractPlugin.loader, ’css-loader’, ’sass-loader?indentedSyntax’], }, { test: /.(png|jpg|gif|svg|ico)$/, loader: ’file-loader’, options: { name: ’[name].[ext]?emitFile=false’, }, }, { test: /.(eot|svg|ttf|woff|woff2)(?S*)?$/, loader: ’url-loader’, options: { esModule: false, limin: 10000, name: 'font/[name].[hash:8].[ext]' } } ], }, plugins: [ new VueLoaderPlugin(), new MiniCssExtractPlugin({ filename: ’[name].css’, }), new CopyWebpackPlugin([ { from: ’icons’, to: ’icons’, ignore: [’icon.xcf’] }, { from: ’popup/popup.html’, to: ’popup/popup.html’, transform: transformHtml }, { from: ’manifest.json’, to: ’manifest.json’, transform: (content) => { const jsonContent = JSON.parse(content); jsonContent.version = version; if (config.mode === ’development’) { jsonContent[’content_security_policy’] = 'script-src ’self’ ’unsafe-eval’; object-src ’self’'; } return JSON.stringify(jsonContent, null, 2); }, }, ]) ],};if (config.mode === ’production’) { config.plugins = (config.plugins || []).concat([ new webpack.DefinePlugin({ ’process.env’: { NODE_ENV: ’'production'’, }, }), ]);}if (process.env.HMR === ’true’) { config.plugins = (config.plugins || []).concat([ new ChromeExtensionReloader(), ]);}function transformHtml(content) { return ejs.render(content.toString(), { ...process.env, });}module.exports = config;

我們數(shù)據(jù)改變后,如果想點開插件就查看對應界面,這里就按需引入我們需要的組件,來實現(xiàn)不同的界面展示。

最后附上manifest.json完整的配置

{ 'name': '插件', 'description': '描述', 'version': 2.0, 'manifest_version': 2, 'icons': { '48': 'icons/icon_426.png', '128': 'icons/icon_426.png' }, 'browser_action': { 'default_title': '插件', 'default_popup': 'popup/popup.html' }, 'permissions': [ 'tabs', '<all_urls>' ], 'background': { 'scripts': ['script/background.js'] }, 'content_scripts': [{ 'js': ['script/contentscript.js'], 'matches': [ 'http://*/*', 'https://*/*' ] }]}

以上就是vue開發(fā)chrome插件,實現(xiàn)獲取界面數(shù)據(jù)和保存到數(shù)據(jù)庫功能的詳細內(nèi)容,更多關于vue開發(fā)chrome插件的資料請關注好吧啦網(wǎng)其它相關文章!

標簽: Vue
主站蜘蛛池模板: 四虎视频| 亚洲欧美综合精品久久成人 | 午夜小视频免费 | 亚洲精品成人av | 国产精品久久久久久一级毛片 | 久久高清国产 | 亚洲特级 | 亚洲成人自拍 | 一区二区三区在线免费观看 | av在线免费看片 | 亚洲高清视频一区二区三区 | 激情欧美一区二区三区中文字幕 | 麻豆一区一区三区四区 | 国产欧美精品一区aⅴ影院 毛片视频网站 | 日本三级中国三级99人妇网站 | 中文在线一区 | 久久国产精品一区 | 久久久久久久久久久免费视频 | 天天操网 | 国产亚洲www | 色综合天天综合网国产成人网 | 99久久精品一区二区 | 在线免费视频成人 | 真实国产露脸乱 | 亚洲国产成人av | 欧美激情小视频 | 一区二区在线不卡 | 欧美性猛交xxxx黑人猛交 | 日韩免费视频 | 性免费网站 | 免费在线日韩 | 日本手机在线视频 | 日日夜夜精品免费视频 | 国产成人福利在线 | 99精品国产高清一区二区麻豆 | 看毛片的网站 | 中文字幕自拍偷拍 | 日韩有码在线观看 | h视频免费看 | 日本视频黄 | 麻豆沈芯语在线观看 | 另类天堂av | 亚洲国产精品一区二区久久 | 日韩成人在线看 | 久久久久久av | 免费的污网站 | 国产综合网站 | 欧美高清成人 | 麻豆精品国产传媒 | 国产福利精品一区 | 欧美日韩在线看 | 免费av电影网站 | 中文字幕日韩一区二区三区 | 99免费在线播放99久久免费 | 成年人免费看 | 成人日韩 | 精品成人在线 | 综合天天| 99色综合 | 日韩在线中文字幕 | 不卡免费视频 | 免费观看一级视频 | 久久精品免费 | 欧美大片一区二区 | 一级一片免费视频 | 亚洲香蕉精品 | 成人做爰9片免费视频 | 91精品国产综合久久精品 | 精品视频一区二区 | 国产欧美精品区一区二区三区 | 亚洲视频一区在线 | 免费视频二区 | 日韩h视频| 精品国产乱码久久久久久久软件 | 国产精品99久久久久久久久久久久 | 91麻豆视频 | 亚洲aⅴ天堂av在线电影软件 | 亚洲欧美综合 | 狠狠干很很操 | 青青久久 | 久久久精品日韩 | 亚洲一区国产精品 | 国产剧情一区二区 | 欧洲一区二区三区 | 啪啪免费网站 | 美女视频黄色 | 日本高清无卡码一区二区久久 | 日本一区二区三区四区 | 久久精品久久久 | 亚洲福利一区二区 | 国产在线一区二区三区 | 中文亚洲字幕 | 国内精品在线视频 | 国产成人在线免费观看 | 日韩综合视频在线观看 | 免费在线亚洲 | 成人九色| 久久av一区二区三区亚洲 | 欧美三级在线 | 亚洲精品网址 | 亚洲福利一区二区 | 91精品国产综合久久久久久 | 欧美在线一区二区三区 | 在线 丝袜 欧美 日韩 制服 | 一区二区精品视频 | 国产成人久久精品一区二区三区 | 成人精品在线观看 | 男人亚洲天堂网 | av中文在线 | 日日操天天射 | 一区二区三区在线播放 | 91久久精品国产91久久 | 狠狠操综合网 | 久久小草 | 亚洲一区日韩 | 亚洲精品国偷拍自产在线观看 | 亚洲精品一区二区 | 日韩国产欧美一区 | 久久久久久久国产精品 | 中国特级毛片 | 午夜成人免费电影 | www.天天草 | 亚洲视频三区 | 国产一区二区三区 | 国产精品美女视频 | 超碰在线看| 91一区二区 | 国产福利91精品一区二区 | 国产精品中文字幕在线 | 日本久久国产 | 亚洲激情欧美 | 国产欧美日韩综合精品一区二区 | 亚洲成人av在线 | 亚洲综合无码一区二区 | 99免费精品 | 日韩精品免费视频 | av资源首页| 黄色毛片视频网站 | www.99re| 视频在线一区 | 精品国产一区二区三区在线观看 | 午夜a级理论片915影院 | 亚洲综合视频在线 | 在线观看黄免费 | 日韩一区二区精品 | 久久精彩视频 | 亚洲国产视频一区 | 亚洲一区二区三区免费 | 成人久久久 | 日韩激情综合 | 亚洲国产视频精品 | 国产精品久久久久久中文字 | 精品日韩欧美一区二区在线播放 | 久久久亚洲精品中文字幕 | 欧美电影一区 | 中文字幕一二三区 | a级片在线观看 | 国久久久 | 日本黄色大片免费观看 | 懂色中文一区二区在线播放 | 狠狠躁夜夜躁人人爽天天天天97 | 久久国内精品 | www.99久久久 | 看亚洲a级一级毛片 | 亚洲免费在线播放 | 91在线免费看 | 欧美日韩视频第一页 | 午夜电影网址 | 国产精品一区二区三区免费视频 | 中文字幕在线视频观看 | 午夜视频在线播放 | 免费国产wwwwwww网站 | 国产精品成人一区二区三区夜夜夜 | 欧美日本一区二区三区 | 国产精品91视频 | 成人免费毛片高清视频 | 久久精品免费 | 国产精品视频成人 | 经典法国性xxxx精品 | 欧美在线a | 国产高清一区二区三区 | 国产亚洲一区二区三区在线观看 | 欧美日韩在线观看一区二区三区 | 欧美成人激情视频 | 欧美日韩免费一区二区三区 | 国产高清精品在线 | 日本狠狠色 | 日韩视频精品在线 | 成人亚州| 国产大毛片| 九九热精品视频 | av影片在线播放 | 亚洲成人av在线播放 | 亚洲精品乱码久久久久久 | 这里只有精品视频 | 女人毛片a毛片久久人人 | 草草视频在线播放 | 日本久久网站 | 日韩高清在线一区 | 亚洲 成人 av | 国产精品精品视频一区二区三区 | 不卡的免费av | 剑来高清在线观看 | 日韩三级在线免费 | 国产中文视频 | 免费高清av | 中国一级毛片免费 | 国内精品久久久久国产 | 欧美成人黄色小说 | 国产精品久久久爽爽爽麻豆色哟哟 | 天天曰夜夜操 | 国产免费天天看高清影视在线 | 日本中文字幕一区二区 | 亚洲综合婷婷 | 玖玖精品| 久久成年人视频 | 亚洲精品一区二三区不卡 | 99爱视频 | 美女国产网站 | 免费看片www| 日韩欧美视频一区 | 亚洲高清在线观看 | 在线免费观看色视频 | 在线视频 欧美日韩 | 成人伊人| 一级做a毛片 | 久久精品亚洲精品国产欧美 | 在线观看亚洲精品视频 | 日韩精品一区二区三区在线 | 亚洲午夜精品片久久www慈禧 | 日本激情网| 国产精品美女 | 免费av片 | 欧美天堂| 亚洲精品一二三四五区 | 综合伊人 | 亚洲福利社区 | 热久久这里只有精品 | 一区二区三区免费在线 | 欧美在线| 99re热精品视频国产免费 | 久久久精品一区 | 精品国产31久久久久久 | 日本三级在线观看网站 | 午夜a级理论片915影院 | 在线观看免费国产 | 久久久精品一区 | 亚洲视频三区 | 欧美日韩综合视频 | 一区二区中文字幕 | 伊人天堂在线 | 午夜激情在线播放 | 99久久久久国产精品免费 | 精品久久久久一区二区国产 | 国产男女视频在线观看 | 日韩视频一区二区三区四区 | 91精品国产综合久久久久久丝袜 | 精品国产一区二区三区性色av | 国产欧美日韩中文字幕 | 久久国产一区二区 | 国产色在线 | 99这里只有精品视频 | 亚洲中出 | 国产一区视频在线 | 欧美成人影院在线 | 亚洲精品区 | 看毛片网 | 国内精品成人 | 亚洲精品二区三区 | 国产精品一区二区在线 | 五月天婷婷综合 | 爱爱视频网站 | 亚洲视频在线观看网站 | 精品国产乱码久久久久久蜜柚 | 国产一区二区三区视频在线观看 | 亚洲欧美视频 | 天天操狠狠操网站 | 999国产一区二区三区四区 | 亚洲国产高清高潮精品美女 | 成人欧美一区二区三区白人 | 精品三级三级三级三级三级 | 成人免费在线网址 | 91国视频| 国产在视频一区二区三区吞精 | 国产在线一二 | 不卡一区二区三区视频 | 中文字幕在线视频免费播放 | 99精品欧美一区二区三区 | 亚洲高清在线 | 日韩精品一区二区三区在线播放 | 91久久看片| 一区二区三区av | 久久精品网 | 美国黄色毛片 | 久久久久久久久久久免费视频 | 国产激情视频在线观看 | 超碰av在线 | 国产福利视频 | 日韩中文字幕在线观看 | 亚洲一区二区中文字幕 | 国产剧情一区二区三区 | 久久亚洲天堂 | 成人免费视频观看 | 狠狠干美女 | 日本高清无卡码一区二区久久 | 国产精品第一国产精品 | 久久久久国产一区二区三区 | 久久久久亚洲国产 | 久久精品99国产精品亚洲最刺激 | 天天碰天天操 | 国产一区二区三区视频 | 国产日产精品一区二区三区四区 | 国产欧美日韩在线观看 | 欧美在线观看免费观看视频 | 国产一区二区三区久久 | 亚洲欧美综合乱码精品成人网 | 成人在线黄色 | 91在线一区二区 | 在线播放一区二区三区 | 91精品久久久久久久久 | 欧美国产91| 91.xxx.高清在线 | 精品国产一区二区在线 | 蜜桃视频一区二区 | 高清国产午夜精品久久久久久 | 欧美九九 | 99色在线视频 | 日本一区二区高清不卡 | 亚洲视频在线看 | 永久免费av | 中文字幕av一区二区三区 | 亚洲综合第一页 | 9999国产精品欧美久久久久久 | 国产a级毛片 | 精品日韩一区二区 | 在线免费视频一区 | 99亚洲 | 欧美一区二区三区精品 | 在线观看免费av网 | 六月丁香在线观看 | 欧美xxxx黑人又粗又长 | 欧美日本免费 | 2019中文字幕视频 | 亚洲黄色一区二区三区 | 久久99精品久久久久久琪琪 | 毛片av在线播放 | 久久精品久久久久 | 狠狠综合久久av一区二区老牛 | 欧洲精品在线观看 | 国产精品久久久久久久久久免费 | 91一区二区 | 国产精品一二区 | 在线成人亚洲 | 久久av一区二区三区 | 精品国产一区二区三区久久影院 | 国产一级片一区二区三区 | 亚洲第一色片 | 欧美日韩在线精品 | 亚洲国产精品久久人人爱 | 精品一区视频 | 久久久久亚洲精品 | 人人精久 | 国产剧情一区二区 | 日本二区 | www..99re| 夜夜草视频 | 一区二区三区不卡视频 | 超碰激情 | 99精品一区二区三区 | 先锋资源在线观看 | 中文字幕1区 | 99爱免费观看国语 | 日本成人在线视频网站 | 日韩av一区二区在线观看 | 久久精品视频网站 | av三级在线免费观看 | 成人在线h | 插插插干干干 | 国产一区二区在线播放 | 精品欧美乱码久久久久久 | 国产精品久久久久久久久久 | 成年片 | 亚洲大片一区 | av成人毛片 | 精品亚洲一区二区三区四区五区 | 91看片淫黄大片一级在线观看 | 国产精品人人做人人爽人人添 | 秋霞在线一区 | 国产成人精品久久二区二区 | 精品三级在线观看 | 欧美在线视频一区二区 | 中文字幕成人在线 | 成人亚洲精品777777大片 | 老司机在线精品视频 | 成人免费毛片高清视频 | 亚洲无吗视频 | 国产免费av在线 | 国产欧美一二三区在线粉嫩 | 国产免费一区二区三区最新不卡 | 色婷婷国产精品久久包臀 | 国产成人免费在线观看 | 国产成人精品一区二区三区视频 | 久久成人国产 | 国产区视频在线观看 | 日韩视频在线免费观看 | 欧美一级视频在线观看 | 一级毛片免费播放 | 国产精品国产 | 欧美日韩亚洲成人 | 国产亚洲网站 | 欧美日韩不卡合集视频 | 在线视频中文字幕 | 伊人爱爱网 | 成人av播放 | 日韩视频中文字幕 | 国产精品久久久久无码av | 色婷婷亚洲一区二区三区 | 亚洲色图综合 | 亚洲精品在线免费播放 | 欧美在线观看免费观看视频 | 在线欧美日韩 | 亚洲一区久久 | 国产午夜精品一区二区三区视频 | av网站免费| 日日摸夜夜添夜夜添高潮视频 | 亚洲一区久久 | 国语av在线| 中文字幕日韩欧美 | 色视频网站免费看 | 日本久久视频 | 欧美亚洲免费 | 久久精品| 91久久久久| 国产精品成人在线视频 | 亚洲精选一区 | 国产精品久久久久久久7电影 | 日韩精品久久久久 | 欧美亚洲天堂 | 中文字幕乱码亚洲精品一区 | 亚洲国产精品t66y | 国产中文视频 | 国产精品免费av | hh99me在线观看| 国产日产精品一区二区三区四区 | 国产精品揄拍一区二区久久国内亚洲精 | 久久精品综合 | 国产精品久久久久久久久晋中 | 久在线草 | 99国产视频 | 国产精品亚洲精品 | 欧美在线视频一区 | 欧美成年网站 | 一区二区三区精品 | 亚洲自拍偷拍av | 亚洲黄色国产 | 日韩成人一级片 | 精品久久久久久久久久久久久久久久久久久 | 国产精品久久久久久久久久免费 | 国产精品精品视频 | 国产成人精品免高潮在线观看 | 中文字幕欧美在线观看 | 亚洲免费精品 | 观看av | 欧美综合一区二区三区 | 亚洲福利精品 | 一区在线视频观看 | 亚洲欧美自拍视频 | 免费一区二区三区 | 亚洲精品成人在线 | 天天综合视频 | 一级色网站| 亚洲午夜精品a | 性色浪潮 | 中文字幕第90页 | 极品久久久久久 | 久久久久久久国产精品 | 99中文字幕| 一区二区网站 | 美女视频一区 | 日韩一区精品视频 | 国产精品久久久久久久免费大片 | 中文字幕国产一区 | 亚洲欧美精品一区 | 久久中文字幕一区二区三区 | 国产在线精品一区二区三区 | 欧美精品在线一区二区三区 | 亚州国产精品 | 亚洲精品乱码久久久久久蜜桃不卡 | 台湾av在线 | 亚洲人成网站999久久久综合 | 久久国产精品久久久久久 | 久久国产精品一区二区 | 久久99精品国产麻豆婷婷洗澡 | 91精品国产人妻国产毛片在线 | 日韩欧美在线观看一区二区三区 | a∨在线观看 | 国产国拍亚洲精品av | 九色91九色porny永久 | 午夜视频| 日韩在线观看中文字幕 | 91在线视频观看 | 成人免费在线视频播放 | 日韩欧美在线一区二区 | 欧美人体一区二区三区 | 久久99久久99精品免观看粉嫩 | 亚洲国产欧美一区二区三区久久 | 久久久久久久久久影院 | 亚洲伦理一区 | 国产精品九九九 | 久久精品国产99 | 一区二区在线不卡 | 女同理伦片在线观看禁男之园 | 99精品免费视频 | 国产亚洲精品精品国产亚洲综合 | 免费亚洲成人 | 久久精品国产99精品国产亚洲性色 | 成人免费视屏 | 成人免费小视频 | 一区二区三区精品 | 欧美日韩福利视频 | 免费在线成人 | 国产在亚洲 线视频播放 | 97久久久久久久久久久久 | 欧美成人一区二区 | 亚洲一级毛片 | 91av导航| 免费一级在线观看 | av在线第一页 | 精品成人免费一区二区在线播放 | 国产精品第一国产精品 | av网站观看 | 九九热精 | 9色porny自拍视频一区二区 | h视频在线免费 | 欧美aaa大片 | 国产单男| 亚州精品天堂中文字幕 | 成人免费aaa | 美女天堂| 国产一区二区三区网站 | 国产女人和拘做受在线视频 | 欧美色欧美亚洲另类七区 | 中文字幕日韩欧美 | 91久久精品国产91久久性色tv | 青青草在线视频免费观看 | 黄色片免费观看 | 中文字幕在线观看av | 亚洲欧美一区二区三区四区 | 亚洲视频一区在线 | 国产福利一区二区三区四区 | 伊人久久爱 | 国产一区二区av | 在线成人国产 | 亚洲视频综合 | 欧美日韩视频 | 中文字幕三区 | 欧美日韩视频在线第一区 | 操操操av | 日干夜干天天干 | 久久久久久久 | 欧美视频精品 | 久久综合久久综合久久 | 91精品久久久久久久久 | 国产中文字幕一区 | 精品自拍视频 | 中文字幕在线一区 | 三区在线 | 91视频在线 | 日韩精品免费在线视频 | 91国内精品久久 | 久草视频在线首页 | 欧美日韩在线免费观看 | 一区二区免费在线播放 | 一区二区三区在线播放 | 久久久久久久成人 | 国产精品久久久久久久久软件 | 精品久久久久一区二区国产 | 免费成人在线观看视频 | 毛片免费看 | 日韩视频欧美视频 | 久久99精品久久久久久琪琪 | 在线免费av观看 | 国产二区三区 | 国产久| 国产精品日韩欧美一区二区三区 | 精品欧美日韩 | 国产成人免费视频网站高清观看视频 | 国产精品久久九九 | 欧美九九九 | 天天舔天天爽 | 中文字幕一区在线观看视频 | 午夜免费视频 | www.伊人| 亚洲va欧美va天堂v国产综合 | 国产乱码精品一区二区三区忘忧草 | 成年人视频免费在线看 | 日本丶国产丶欧美色综合 | 日韩激情网 | 一区免费视频 | 女同久久| 亚洲国产成人在线视频 | 日韩三级 | 日韩成人国产 | 亚洲欧美日韩在线 | 欧美日本亚洲 | 一区二区三区免费 | 精品视频免费观看 | 91精品国产综合久久久久久丝袜 | 伊人春色在线播放 | 91麻豆精品久久久久蜜臀 | 久久久久国产精品视频 | 黑人精品xxx一区一二区 | 国产超碰人人爽人人做人人爱 | 欧美aaa视频| 久热免费在线观看 |