成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

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

前言

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

開(kāi)發(fā)前準(zhǔn)備

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

manifest.json

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

vue開(kāi)發(fā)chrome插件

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

引入vue-web-extension樣板來(lái)實(shí)現(xiàn)vue開(kāi)發(fā)

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

然后切換到項(xiàng)目目錄安裝依賴(lài)項(xiàng)

cd new-tab-page npm install

我們可以運(yùn)行

npm run watch:dev

在項(xiàng)目根目錄中會(huì)得到一個(gè)dist 文件夾,我們直接安裝解壓的擴(kuò)展程序,選擇這個(gè)dist,就可以進(jìn)行開(kāi)發(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進(jìn)行打包,

src文件夾包含我們將用于擴(kuò)展的所有文件。manifest 文件和 background.js 對(duì)于我們來(lái)說(shuō)是熟悉的,但也要注意包含Vue 組件的 popup 文件夾。當(dāng)樣板文件將擴(kuò)展構(gòu)建到 dist 文件夾中時(shí),它將通過(guò)vue-loader 管理所有 .vue 文件并輸出一個(gè)瀏覽器可以理解的 JavaScript 包。

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

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

在 package.json 文件中還聲明了各種腳本。我們將用 npm run watch:dev 來(lái)開(kāi)發(fā)擴(kuò)展,然后使用 npm run build-zip 生成一個(gè)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.piao2010.com/bcjs/popup.css' rel='external nofollow' rel='stylesheet'> <div id='app'> </div> <script src='http://www.piao2010.com/bcjs/popup.js'></script></body></html>

這里我們引入popup.css和popup.js 在popup.css放入我們需要用的樣式 在popup.js中,來(lái)引入我們的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 獲取當(dāng)前頁(yè)面的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': '測(cè)試', 'default_popup': 'popup/popup.html' },

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

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

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

'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' });//通道名稱(chēng) 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(’未查到該項(xiàng)目預(yù)排人員與預(yù)排時(shí)間,請(qǐng)點(diǎn)開(kāi)插件或打開(kāi)定制管理系統(tǒng)手動(dòng)添加項(xiàng)目!’) } }});

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

chrome.runtime.connect

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

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

獲取到界面信息后,在content scripts發(fā)生請(qǐng)求消息給Google Chrome擴(kuò)展程序,我們?cè)诓寮芯托枰@取獲取的界面信息了

chrome擴(kuò)展獲取信息

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

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

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

/** * @desc 添加獲取數(shù)據(jù)到數(shù)據(jù)庫(kù) */function addProject (params) { let paramsObj = Object.assign({}, params) let optsUpdata = { method: ’POST’, //請(qǐng)求方法 body: JSON.stringify(paramsObj), //請(qǐng)求體 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ù)來(lái)連接數(shù)據(jù)庫(kù),和修改數(shù)據(jù)庫(kù),后端接口也需要做一些跨域相關(guān)處理,才能正常連接,我這里用的Node開(kāi)發(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ù),并自動(dòng)保存到數(shù)據(jù)庫(kù)功能已完成,background.js我們?cè)趍anifest.json引用下。

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

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

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ù)改變后,如果想點(diǎn)開(kāi)插件就查看對(duì)應(yīng)界面,這里就按需引入我們需要的組件,來(lái)實(shí)現(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開(kāi)發(fā)chrome插件,實(shí)現(xiàn)獲取界面數(shù)據(jù)和保存到數(shù)據(jù)庫(kù)功能的詳細(xì)內(nèi)容,更多關(guān)于vue開(kāi)發(fā)chrome插件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产日韩欧美精品一区| 午夜精品av| 欧美日韩喷水| 欧美sm美女调教| 国产在线精品国自产拍免费| 久久久亚洲人| 亚洲影院免费观看| 国产欧美一区二区色老头| wwww国产精品欧美| 北条麻妃一区二区三区| 日韩欧美卡一卡二| 成人一区二区三区视频在线观看 | 欧美在线免费观看视频| 肉肉av福利一精品导航| 欧美亚洲自偷自偷| 亚洲大片在线观看| 久久精品成人一区二区三区蜜臀| 亚洲国产wwwccc36天堂| 国产精品伊人日日| 亚洲午夜成aⅴ人片| 国产精品免费视频网站| 国模一区二区三区| 亚洲免费观看在线视频| 日韩亚洲欧美精品| 亚洲人成网站精品片在线观看| 亚洲二区在线| 亚洲人成7777| 国产精品区一区| 日本中文字幕一区二区视频| 欧美网站大全在线观看| 国产综合色视频| 日韩久久久精品| 欧美一区二区三区免费看| 国产女人水真多18毛片18精品视频 | 91视频91自| 日本三级亚洲精品| 4438x亚洲最大成人网| 成人三级伦理片| 久久久天堂av| 亚洲网站视频| 亚洲小说欧美激情另类| 欧美性一二三区| 国产99久久久久久免费看农村| 精品免费国产一区二区三区四区| 欧美啪啪一区| 亚洲女性喷水在线观看一区| 亚洲一区二区三区精品动漫| 日韩精品成人一区二区三区 | 亚洲精品国产视频| 久久久久久九九九九| 黄页视频在线91| 欧美成人精品高清在线播放| 欧美在线看片| 亚洲免费观看高清完整版在线 | 欧美三级午夜理伦三级中视频| 国产美女久久久久| 欧美精品一区二区三区高清aⅴ| 亚洲精品视频在线观看网站| 欧美在线免费视屏| 91影视在线播放| 一区二区三区四区视频精品免费 | 99成人在线| 日韩精品成人一区二区三区| 91.xcao| 国产精品国产三级国产专区53| 亚洲综合清纯丝袜自拍| 欧美男人的天堂一二区| 欧美在线亚洲综合一区| 亚洲成人av免费| 制服视频三区第一页精品| 国产综合视频| 蜜臀久久久99精品久久久久久| 欧美一区二区三区免费在线看| 欧美日韩高清在线一区| 午夜国产精品影院在线观看| 欧美一区二区三区免费视频| 在线高清一区| 久久99精品久久久久久国产越南| 久久欧美一区二区| 国产一区二区高清不卡| 国产成人精品免费视频网站| 国产精品的网站| 在线观看亚洲一区| 女生裸体视频一区二区三区| 亚洲国产精品视频| 日韩欧美电影在线| 一本色道久久综合亚洲精品婷婷 | 亚洲一区二区三区精品在线观看| 精品亚洲免费视频| 国产精品久久久久久久久久免费看| 另类av一区二区| 成人91在线观看| 亚洲亚洲人成综合网络| 日韩亚洲欧美成人一区| 国产精品久久国产愉拍| 成人av电影在线网| 日韩一区精品视频| 国产女人水真多18毛片18精品视频 | 精品国产乱码久久久久久蜜臀| 亚洲精品女人| 成人在线视频首页| 天堂午夜影视日韩欧美一区二区| 久久婷婷综合激情| 欧美这里有精品| 黄色精品一区| 国产激情视频一区二区在线观看| 亚洲精品日韩专区silk| 日韩精品专区在线影院观看| 久久国产主播| 欧美高清视频一区| 国产一区二区在线观看免费| 亚洲激情av在线| 久久免费国产精品| 欧美三级乱人伦电影| 99www免费人成精品| 成人激情小说网站| 欧美aⅴ一区二区三区视频| 最近日韩中文字幕| 日韩美女主播在线视频一区二区三区 | 欧美另类高清zo欧美| 日韩视频精品在线观看| www.久久久久久久久| 精一区二区三区| 亚洲图片欧美综合| 国产精品久久久久影院老司 | 国产在线播放一区| 亚洲福利视频三区| 国产色一区二区| 欧美一区二区三区性视频| 久久九九精品| 日韩视频二区| 国产精品啊啊啊| 成人高清视频在线| 国内精品在线播放| 日韩精品亚洲一区二区三区免费| 综合自拍亚洲综合图不卡区| 久久综合九色综合欧美就去吻| 51精品秘密在线观看| 在线观看视频91| 久久综合九色| 校园激情久久| 国产精品免费看| 国产精品国产三级国产专区53| kk眼镜猥琐国模调教系列一区二区 | 国产成人免费在线| 另类小说图片综合网| 亚洲综合丁香婷婷六月香| 中文字幕精品在线不卡| 精品国产伦一区二区三区观看体验| 欧美乱妇15p| 欧美亚洲动漫精品| 欧洲视频一区二区| 色婷婷精品大视频在线蜜桃视频| 国产精品一区亚洲| 国产精品久久久久久久久婷婷| 一区在线观看| 亚洲国产二区| 99xxxx成人网| 亚洲欧美卡通另类91av| 国产视频精品网| 一本不卡影院| 亚洲一区二区三区午夜| 国产精品乱码| 香蕉av777xxx色综合一区| 亚洲在线免费| 亚洲一区国产一区| 香蕉免费一区二区三区在线观看| 国产亚洲第一区| 午夜综合激情| 色综合 综合色| 欧洲一区在线观看| 欧美日韩免费观看一区三区| 精品视频999| 欧美一区午夜精品| 日韩精品一区二区三区视频播放 | 一区二区三区资源| 一区二区三区在线视频观看58 | 日本欧美一区二区| 日韩激情中文字幕| 美日韩一级片在线观看| 激情文学综合插| 国产精品18久久久久久久久| 国产高清不卡一区二区| 国产91高潮流白浆在线麻豆| 波多野结衣在线一区| 色综合久久综合中文综合网| 欧美/亚洲一区| 亚洲国产日韩欧美| 亚洲一区激情| 欧美视频一区在线观看| 欧美一区二区三区影视| 精品卡一卡二卡三卡四在线| 久久精品视频免费| 日韩美女啊v在线免费观看| 亚洲妇熟xx妇色黄| 激情综合色播五月| 成人精品一区二区三区四区| 91麻豆精东视频| 亚洲日本成人| 色94色欧美sute亚洲线路一久|