• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    自定義組件的軟件快速開發(fā)方法*

    2019-12-30 07:03:08穆澤慧雷聚超胡靜宜王亞銘趙雅霖
    關(guān)鍵詞:開發(fā)方法窗體頁面

    穆澤慧,雷聚超,胡靜宜,王亞銘,趙雅霖

    (西安工業(yè)大學(xué) 計算機科學(xué)與工程學(xué)院,西安 710021)

    隨著信息時代的到來,人們對軟件的需求越來越大。市場上一般使用C#、Delphi、Java、PHP等工具進(jìn)行軟件開發(fā)[1],在使用這類軟件進(jìn)行開發(fā)時,需要很長的周期來完成對應(yīng)的功能需求,同時會出現(xiàn)大量的代碼重復(fù)問題,尤其是在信息化管理系統(tǒng)(ERP系統(tǒng))中有很多類似的業(yè)務(wù)邏輯,在每個模塊中都需要對數(shù)據(jù)進(jìn)行最基本的如增加、修改、刪除和取消等操作[2-3]。目前,市場上的軟件均為B/S[4]、C/S[5]結(jié)構(gòu),使用Java、C等語言開發(fā)B/S和C/S結(jié)構(gòu)時,連接數(shù)據(jù)庫或服務(wù)器的工作比較繁瑣。近年來,隨著DataSnap技術(shù)[6]的出現(xiàn),Delphi 將其集成在功能平臺之中,為多層軟件(C/SS)[7]的開發(fā)提供了極大的便利。Delphi在使用DataSnap技術(shù)構(gòu)建三層服務(wù)器時提供了一套FireDAC技術(shù)[8]的組件,該組件可以通過相關(guān)的設(shè)置搭建服務(wù)器[9-10],同時在客戶端中引入服務(wù)器連接組件并進(jìn)行設(shè)置,可直接連接到服務(wù)器。

    為解決上述問題,本文擬在Delphi中通過設(shè)計自定義組件來達(dá)到軟件快速開發(fā)的目的,用DataSnap技術(shù)構(gòu)建三層架構(gòu)[1],實現(xiàn)廣域網(wǎng)的C/S應(yīng)用,同時提高編程人員的效率,減少代碼重復(fù)率。

    1 預(yù)備知識

    在系統(tǒng)開發(fā)過程中可以根據(jù)需求分析整理出相應(yīng)的邏輯功能,而這其中有部分邏輯功能是重復(fù)的,這導(dǎo)致在軟件設(shè)計過程中需要進(jìn)行很多重復(fù)性的工作。若能將這些重復(fù)的工作放在一個組件中,通過相關(guān)屬性設(shè)置來完成其對應(yīng)功能,就可極大減少代碼的重復(fù)率,提高編程人員的開發(fā)速度,自定義組件由此應(yīng)運而生。

    Delphi組件是一個對象庫,也是一個類。在Delphi中所有對象的基類都是TObject,組件的最基類也是TObject,其結(jié)構(gòu)如圖1所示。

    圖1 Delphi的類結(jié)構(gòu)Fig.1 Class structure of Delphi

    該結(jié)構(gòu)中組件的類層次為:TObject→TPersistent→TComponent→TControl。

    TComponent是所有Delphi組件的基類,所有要注冊到IDE直接進(jìn)行可視化的對象庫均要從這個類繼承,TComponent提供了必不可少的信息以使組件能在Delphi的IDE上運作。TComponent 衍生出的TControl的類是所有可視化控件的基類,開發(fā)出的組件都基于TComponent。當(dāng)創(chuàng)建一個新的組件時,通過該層次關(guān)系可從已存在的一個類的類型中派生出新的類,添加到組件的庫中。

    2 基于自定義組件的快速開發(fā)方法

    2.1 自定義組件的創(chuàng)建

    在Delphi中開發(fā)自定義組件時,創(chuàng)建一個新組件(New Component)需要選擇組件父類的類型,生成對應(yīng)的.pas文檔,在文檔中添加組件特有的屬性、方法和事件以完成它的相關(guān)功能;對其文檔進(jìn)行編譯和安裝;在面板庫中找到新安裝的組件進(jìn)行業(yè)務(wù)和功能性測試以滿足功能要求。該過程必須完成以下的步驟:① 為新的組件創(chuàng)建單元,如:unit1.pas;② 從已有組件類型中派生組件,即繼承已存在的組件的類型,如TButton、TDBEditEh等;③ 為新的組件添加特有屬性、方法和事件完成其獨特的功能;④ 向IDE注冊組件;⑤ 為組件創(chuàng)建位圖;⑥ 創(chuàng)建包并在IDE中安裝組件;⑦ 為組件與其屬性、方法和事件創(chuàng)建幫助文檔。

    創(chuàng)建新組件一般選擇已存在的組件對其進(jìn)行二次開發(fā),并修改或增加組件的屬性、方法和事件[11]。屬性是組件中明顯的部分,應(yīng)用程序開發(fā)人員可以在設(shè)計時看到并對其進(jìn)行操作。同時,組件在窗體設(shè)計器中發(fā)生反應(yīng),立即會得到反饋。設(shè)計良好的屬性會使組件易被其他開發(fā)人員使用及維護(hù)。事件是把所發(fā)生的事情鏈接到一些代碼的機制。組件的方法是內(nèi)置于類結(jié)構(gòu)中的過程和函數(shù),需要遵循的標(biāo)準(zhǔn)為:消除依賴、命名方法、保護(hù)方法及聲明方法等。

    2.2 快速開發(fā)方法的原理

    快速開發(fā)模式通過開發(fā)模板組件即自定義組件來實現(xiàn)軟件系統(tǒng)的快速開發(fā)[12]。開發(fā)模板由數(shù)據(jù)操作模塊與數(shù)據(jù)傳輸模塊組成,快速開發(fā)模型的結(jié)構(gòu)如圖2所示。

    圖2 快速開發(fā)模型Fig.2 Rapid development model

    其原理是從模板組件的屬性中獲取到當(dāng)前的表名之后,連接服務(wù)器組件來獲取數(shù)據(jù)庫中表的數(shù)據(jù),同時由初始化組件獲取當(dāng)前屏幕的分辨率從而計算出TDBGrid、TGroupBox、功能性組件的位置,最終實現(xiàn)窗體分辨率自適應(yīng)效果。其中TGroupBox中放置數(shù)據(jù)感應(yīng)編輯框,編輯框與TDBGrid、數(shù)據(jù)庫對應(yīng)的字段進(jìn)行關(guān)聯(lián),實現(xiàn)實時更新。

    數(shù)據(jù)操作模塊以Delphi的組件開發(fā)技術(shù)為基礎(chǔ),引入“公有”這一概念,對系統(tǒng)所需的數(shù)據(jù)表操作并進(jìn)行歸納,將使用頻率高的操作通過組件開發(fā)的方式直接編寫,如:特定可視化組件中TButton和TDBEdit等,形成公有自定義組件。公有組件成為承載特定功能的開發(fā)元素。每個自定義組件都包含以下一種或幾種過程:

    1) 建立包含新部件的庫單元;

    2) 有部件類型中繼承得到新的部件類型;

    3) 增加屬性、方法和事件;

    4) 用Delphi注冊部件;

    5) 為部件的屬性方法和事件建立Help文件。

    在一個頁面中有很多自定義組件,如果要獲取當(dāng)前的程序流程信息、主表信息、操作人信息和從表信息等,需要設(shè)計一個自定義模板組件放置在每一個頁面中,模板組件的屬性設(shè)計見表1。

    表1 模板屬性

    接口組件中包含了數(shù)據(jù)表中對數(shù)據(jù)進(jìn)行操作識別的各個字段,并將其作為參數(shù)。開發(fā)過程中通過接口組件對各個字段進(jìn)行賦值,模板內(nèi)的其他組件通過取接口組件的各屬性值來獲得相應(yīng)的字段值。在創(chuàng)建模板組件時,通過修改已有TButton組件添加屬于模板組件特有屬性和方法。在創(chuàng)建模板的組件時,一定要添加聲明。模板組件的核心代碼為:

    TMB = class(TButton)//聲明模板組件

    Smb_mb_name:string;//模板組件名稱

    Smb_mb_tablename:string;//當(dāng)前表名

    Smb_pmb_tablename:string;//當(dāng)前編號

    Procedure Fmb_mb_tablename(const Value:string);//添加模板方法,獲取屬性值

    procedure Fmb_czr(const Value:string);

    constructor Create(Aowner:TComponent);override;//創(chuàng)建模板組件

    property mb_lcmc:string read Fmb_lcmc write Setmb_lcmc;//添加模板事件完成其功能

    procedure Register;//模板組件的注冊

    RegisterComponents('SJ',[TMB]);//將模板組件SJMB放在SJ文件下

    constructor TSJMB.Create(Aowner:TComponent);//模板組件的初始化即形狀、名稱、字體等詳細(xì)需求

    inherited Create(Aowner);{執(zhí)行繼承的其父類初始化過程 }

    self.Text :='模板';

    self.Font.Family :='宋體';

    self.Font.Size:=11;

    2.3 自定義組件設(shè)計

    2.3.1 數(shù)據(jù)的獲取

    一般設(shè)計功能性的自定義組件,需要獲取數(shù)據(jù)或輸出數(shù)據(jù)。在每一個頁面上有很多數(shù)據(jù)型組件,可以通過設(shè)計組件的命名規(guī)則找到對應(yīng)的數(shù)據(jù)型組件。如:在設(shè)置組件中制定統(tǒng)一的命名規(guī)則,如text_XXXX,其中XXXX為數(shù)據(jù)庫表中的字段名,text為字段的類型,根據(jù)text找到所需要的組件,根據(jù)XXXX將組件與數(shù)據(jù)庫中字段對應(yīng)。

    2.3.2 數(shù)據(jù)的傳遞

    使用JSON進(jìn)行數(shù)據(jù)傳遞。JSON是一種輕量級的數(shù)據(jù)交換格式,基于ECMAScript的一個子集,采用完全獨立于編程語言的文本格式來存儲和表示數(shù)據(jù)。JSON中有兩種結(jié)構(gòu):對象和數(shù)組。JSON的值由數(shù)字、字符串、邏輯值、數(shù)組、對象和null等組成。使用JSON作為客戶端與服務(wù)器之間的數(shù)據(jù)交換格式,JSON數(shù)據(jù)格式可以直接為服務(wù)器使用,大大簡化了客戶端與服務(wù)器的代碼開發(fā)量,更易于維護(hù)。而且數(shù)據(jù)格式比較簡單,易于讀寫,且格式均為壓縮的,占用帶寬小。

    2.3.3 功能性組件之間互斥事件

    當(dāng)按鈕的OnClick被執(zhí)行后,為了避免數(shù)據(jù)的混亂,必須使不相關(guān)的按鈕處于無效的狀態(tài)。例如,在信息化管理系統(tǒng)中當(dāng)點擊添加按鈕的時候,修改、刪除、歸檔、數(shù)據(jù)導(dǎo)出和返回等按鈕必須處于無效狀態(tài),而保存和取消按鈕則必須處于有效狀態(tài)。當(dāng)保存或取消按鈕被點擊后,增加、修改、歸檔和返回等按鈕應(yīng)該處于有效狀態(tài),而保存和取消按鈕應(yīng)該處于無效狀態(tài)。因此,必須在組件的OnClick事件中找到窗體中的相關(guān)組件進(jìn)行互斥性操作設(shè)置。

    2.4 自定義組件的應(yīng)用

    在基于DataSnap的三層信息化管理系統(tǒng)中,每一個窗體Form都是由很多組件構(gòu)成的。在窗體Form中實現(xiàn)其功能的步驟為:① 添加連接DataSnap服務(wù)器的組件;② 將TDBGrid組件和數(shù)據(jù)感應(yīng)組件添加到Form中,通過數(shù)據(jù)關(guān)聯(lián)組件如TDataSource將服務(wù)器中的數(shù)據(jù)用TDBGrid進(jìn)行顯示;③ 將TGroupBox組件的數(shù)據(jù)編輯框與TDBGrid組件相關(guān)聯(lián),并進(jìn)行實時顯示;④ 添加窗體Form所需要的功能性組件,其中功能性組件包括必須的和非必須的,必須的組件包含模板組件和初始化組件,非必須的組件包含添加組件、刪除組件、審核組件和歸檔組件等。其頁面的整體結(jié)構(gòu)層次如圖3所示。對于圖3中功能性組件之間的關(guān)聯(lián),以增加組件和保存組件為例。

    ① 單擊增加組件后,其本身將處于無效狀態(tài),頁面上除取消組件、保存組件和編輯框處于有效狀態(tài)外,其他組件均處于無效狀態(tài)。若單擊增加組件后,頁面上所有組件都處于有效狀態(tài),則單擊TDBGrid組件、修改組件和刪除組件等會出現(xiàn)數(shù)據(jù)混亂現(xiàn)象。若沒有成功添加數(shù)據(jù)便執(zhí)行刪除操作,則會導(dǎo)致軟件崩潰以致于損壞電腦主機。使取消組件、保存組件和編輯框處于有效狀態(tài)是因為增加的過程是從編譯框中讀取信息,保存組件可以將之前添加的數(shù)據(jù)信息保存到數(shù)據(jù)庫中,取消組件可以取消之前的添加操作。其結(jié)構(gòu)如圖4所示。

    ② 單擊保存組件后,其本身處于無效狀態(tài),頁面上除取消組件、保存組件和編輯框處于有無效狀態(tài)外,其他組件均處于有效狀態(tài)。若單擊保存組件后,頁面上所有組件都處于有效狀態(tài),則單擊取消組件、保存組件和編輯框組件將會使數(shù)據(jù)再次保存病修改,將會出現(xiàn)數(shù)據(jù)混亂不真實甚至導(dǎo)致軟件崩潰以致于損壞電腦主機的現(xiàn)象。使TDBGrid組件、修改組件、刪除組件、上傳組件和審核組件均處于有效狀態(tài)是因為將數(shù)據(jù)成功保存到數(shù)據(jù)庫中后,可以重新對數(shù)據(jù)庫表中的數(shù)據(jù)進(jìn)行操作,不會出現(xiàn)數(shù)據(jù)混亂等狀況。其結(jié)構(gòu)如圖5所示。

    圖3 窗體結(jié)構(gòu)Fig.3 Form structure

    圖4 增加組件結(jié)構(gòu)Fig.4 Structure of the additional components

    圖5 保存組件結(jié)構(gòu)Fig.5 Structure of the saved components

    3 測試與結(jié)果分析

    3.1 測試過程

    1) 在Delphi中創(chuàng)建信息化管理項目。在項目開始之前將自定義組件的包地址引入到項目中,可以在項目設(shè)計的任何一個頁面工具箱中使用自定義組件。

    2) 在Delphi的工具箱中的自定義組件包中可以看到常用的自定義組件,見表2。

    表2 已完成的自定義組件

    3)在頁面中添加需要的組件:連接服務(wù)器組件、功能必要組件(模板組件和初始化組件)和其他功能性組件。在模板組件中添加當(dāng)前頁面的信息,成功連接數(shù)據(jù)庫組件與數(shù)據(jù)顯示如圖6(a)所示,數(shù)據(jù)的顯示包含了TDBGrid、TDBEdit等數(shù)據(jù)組件,同時使用TBindSource組件進(jìn)行數(shù)據(jù)直接關(guān)聯(lián),即數(shù)據(jù)組件進(jìn)行連接,編譯框與數(shù)據(jù)庫中對應(yīng)的字段進(jìn)行關(guān)聯(lián),其結(jié)果如圖6(b)所示。

    3.2 結(jié)果分析

    在項目開發(fā)過程中使用自定義組件開發(fā)方法,只需在頁面上添加所需的功能性組件,并對組件的屬性進(jìn)行設(shè)置,而不需要在OnClick事件中寫入任何代碼即可完成相關(guān)功能。在“供電所標(biāo)準(zhǔn)化作業(yè)流程”系統(tǒng)中使用傳統(tǒng)開發(fā)方法,387個頁面需要200個工作日完成開發(fā)調(diào)試工作,而在“縣級標(biāo)準(zhǔn)化管理流程”系統(tǒng)中使用本文所述的自定義組件方法開發(fā),673個頁面共用28個工作日完成,開發(fā)效率提高了80%以上。使用自定義組件開發(fā)方法的主要工作是開發(fā)組件,組件開發(fā)完成后,便可通過對組件屬性進(jìn)行設(shè)置來完成開發(fā)工作。因此,傳統(tǒng)開發(fā)方法需要2 d完成的窗體,自定義組件開發(fā)方法只需要40 min便可完成。而當(dāng)軟件需要升級修改時,只需修改自定義組件代碼。這就極大減少了程序的Bug,提高了程序的運行質(zhì)量。

    圖7為信息化建設(shè)項目中的窗體效果。開發(fā)時僅需將相應(yīng)組件添加到窗體中并對屬性進(jìn)行設(shè)置即可實現(xiàn)相應(yīng)的功能,達(dá)到軟件快速開發(fā)的目的。

    圖6 頁面上數(shù)據(jù)與對應(yīng)的數(shù)據(jù)組件關(guān)聯(lián)Fig.6 Association of data on the page with the corresponding data components

    圖7 窗體效果Fig.7 Effect of form

    4 結(jié) 論

    文中在Delphi中利用組件的自定義方法,通過對組件父類的繼承并將組件的功能代碼放入組件的相應(yīng)事件中,通過對窗體組件的相關(guān)參數(shù)進(jìn)行設(shè)置,設(shè)計開發(fā)出滿足需求的相關(guān)功能性組件。實驗結(jié)果表明,文中提出的自定義組件開發(fā)方法可提高開發(fā)效率、減少代碼重復(fù)率,為軟件高效運行以及程序的更新、升級提供便利。從已經(jīng)開發(fā)完成的項目來看,傳統(tǒng)開發(fā)方法計劃60 d完成的工作量僅需10 d左右即可完成,工作的效率提高了80%以上,文中方法達(dá)到了軟件高效快速開發(fā)的目的。文中方法可在C#、Java等平臺軟件開發(fā)中變通使用。

    猜你喜歡
    開發(fā)方法窗體頁面
    刷新生活的頁面
    高中英語校本教材的開發(fā)方法
    甘肅教育(2020年14期)2020-09-11 07:58:10
    試談Access 2007數(shù)據(jù)庫在林業(yè)檔案管理中的應(yīng)用
    檔案天地(2019年5期)2019-06-12 05:12:02
    基于FANUC PICTURE的虛擬軸坐標(biāo)顯示界面開發(fā)方法研究
    基于模型開發(fā)方法(MBD)的ABS控制器開發(fā)
    汽車文摘(2014年9期)2014-12-13 13:10:30
    基于LayeredWindow的異形窗體局部刷新
    中文信息(2014年2期)2014-03-06 23:49:14
    職業(yè)教育課程開發(fā)方法應(yīng)用研究
    巧設(shè)WPS窗體控件讓表格填寫更規(guī)范
    同一Word文檔 縱橫頁面并存
    淺析ASP.NET頁面導(dǎo)航技術(shù)
    亚洲av成人一区二区三| 亚洲欧美日韩卡通动漫| 美女高潮的动态| 成人一区二区视频在线观看| 欧美日韩瑟瑟在线播放| 成人三级黄色视频| 51午夜福利影视在线观看| 黄色片一级片一级黄色片| xxx96com| 曰老女人黄片| 久久99热这里只有精品18| 亚洲七黄色美女视频| 午夜激情欧美在线| 免费一级毛片在线播放高清视频| 亚洲av成人不卡在线观看播放网| 国产一区二区激情短视频| 国产亚洲av嫩草精品影院| 99久久综合精品五月天人人| 亚洲av五月六月丁香网| 日韩欧美一区二区三区在线观看| cao死你这个sao货| 国产v大片淫在线免费观看| 韩国av一区二区三区四区| 午夜福利高清视频| 90打野战视频偷拍视频| 最新在线观看一区二区三区| 韩国av一区二区三区四区| 欧美又色又爽又黄视频| 免费观看人在逋| 97超级碰碰碰精品色视频在线观看| 国产1区2区3区精品| 不卡一级毛片| 国产精品日韩av在线免费观看| 99在线视频只有这里精品首页| 久久国产精品人妻蜜桃| 国产高潮美女av| 男女床上黄色一级片免费看| 久99久视频精品免费| 啦啦啦观看免费观看视频高清| 国产亚洲精品久久久久久毛片| 亚洲片人在线观看| 这个男人来自地球电影免费观看| 久久久久精品国产欧美久久久| 网址你懂的国产日韩在线| 精华霜和精华液先用哪个| 日韩欧美免费精品| 99热这里只有精品一区 | 亚洲熟妇中文字幕五十中出| 熟女人妻精品中文字幕| 欧美乱码精品一区二区三区| 国产精品久久久久久亚洲av鲁大| 91av网站免费观看| 熟女少妇亚洲综合色aaa.| 日本熟妇午夜| 国产精品久久久人人做人人爽| 一个人观看的视频www高清免费观看 | 久久久久久久久中文| 老熟妇仑乱视频hdxx| 变态另类丝袜制服| 在线观看免费午夜福利视频| 亚洲av成人一区二区三| 亚洲成人精品中文字幕电影| 久久久久久久精品吃奶| 久久国产精品人妻蜜桃| 又粗又爽又猛毛片免费看| 中文字幕人妻丝袜一区二区| а√天堂www在线а√下载| 母亲3免费完整高清在线观看| 欧美色视频一区免费| 久久久久国产一级毛片高清牌| 最近最新中文字幕大全电影3| 精品国内亚洲2022精品成人| 亚洲国产高清在线一区二区三| av欧美777| 日本免费a在线| 国产麻豆成人av免费视频| 91老司机精品| 黑人巨大精品欧美一区二区mp4| avwww免费| 听说在线观看完整版免费高清| 真人一进一出gif抽搐免费| 国产av一区在线观看免费| 中文字幕高清在线视频| 亚洲自偷自拍图片 自拍| h日本视频在线播放| 日韩欧美 国产精品| 精华霜和精华液先用哪个| 一二三四社区在线视频社区8| 18禁美女被吸乳视频| 别揉我奶头~嗯~啊~动态视频| 欧美日韩亚洲国产一区二区在线观看| 国产av麻豆久久久久久久| h日本视频在线播放| 亚洲精品一区av在线观看| 亚洲精品色激情综合| 欧美zozozo另类| 久久伊人香网站| 国产视频一区二区在线看| 色噜噜av男人的天堂激情| 亚洲七黄色美女视频| 亚洲欧美精品综合久久99| 老司机深夜福利视频在线观看| 午夜福利18| 国产精品精品国产色婷婷| 99热6这里只有精品| 男女做爰动态图高潮gif福利片| 免费大片18禁| 亚洲国产精品久久男人天堂| 成人国产综合亚洲| 免费电影在线观看免费观看| 精品一区二区三区视频在线 | 99久久精品一区二区三区| 午夜视频精品福利| 国产精品爽爽va在线观看网站| 国产成人aa在线观看| 真人做人爱边吃奶动态| 美女大奶头视频| 一个人免费在线观看电影 | 国产成人系列免费观看| 老鸭窝网址在线观看| svipshipincom国产片| 一级黄色大片毛片| 天堂动漫精品| 黄色片一级片一级黄色片| 中文字幕av在线有码专区| 亚洲 国产 在线| 久久久国产精品麻豆| 非洲黑人性xxxx精品又粗又长| 亚洲午夜理论影院| 国产精品香港三级国产av潘金莲| 久久久久国内视频| 日日夜夜操网爽| 国产乱人视频| or卡值多少钱| e午夜精品久久久久久久| 国产伦一二天堂av在线观看| avwww免费| 国产成人影院久久av| 窝窝影院91人妻| 国产精品影院久久| 国产精品久久视频播放| 成人欧美大片| 男女午夜视频在线观看| 这个男人来自地球电影免费观看| 少妇的逼水好多| 亚洲成人中文字幕在线播放| 好男人在线观看高清免费视频| 亚洲成av人片在线播放无| 亚洲成人中文字幕在线播放| 麻豆成人午夜福利视频| 色老头精品视频在线观看| 91麻豆精品激情在线观看国产| 国产真实乱freesex| 欧美日韩国产亚洲二区| 亚洲av免费在线观看| 三级毛片av免费| 国产精品乱码一区二三区的特点| 亚洲av成人av| 女人被狂操c到高潮| 亚洲欧美精品综合一区二区三区| 亚洲精品国产精品久久久不卡| 欧美丝袜亚洲另类 | 99在线视频只有这里精品首页| 欧美日本视频| 久久婷婷人人爽人人干人人爱| 好男人在线观看高清免费视频| 中文资源天堂在线| 91麻豆精品激情在线观看国产| 可以在线观看的亚洲视频| 一个人看视频在线观看www免费 | 成人性生交大片免费视频hd| 成年版毛片免费区| 露出奶头的视频| 成人三级做爰电影| 午夜福利高清视频| 这个男人来自地球电影免费观看| netflix在线观看网站| 久久精品夜夜夜夜夜久久蜜豆| 1024手机看黄色片| 99国产精品一区二区三区| 欧美午夜高清在线| 国产69精品久久久久777片 | aaaaa片日本免费| 国语自产精品视频在线第100页| 老汉色av国产亚洲站长工具| 午夜成年电影在线免费观看| 女人高潮潮喷娇喘18禁视频| 久久九九热精品免费| 亚洲av成人一区二区三| 99精品欧美一区二区三区四区| 非洲黑人性xxxx精品又粗又长| 一二三四在线观看免费中文在| 美女高潮喷水抽搐中文字幕| 人妻久久中文字幕网| 999久久久精品免费观看国产| 极品教师在线免费播放| 国产探花在线观看一区二区| 亚洲美女视频黄频| 日本黄色片子视频| 两个人的视频大全免费| 国产精品 国内视频| 99国产精品99久久久久| 丰满人妻一区二区三区视频av | 色尼玛亚洲综合影院| 午夜视频精品福利| 俺也久久电影网| 亚洲国产日韩欧美精品在线观看 | 成人无遮挡网站| 人人妻人人看人人澡| 国产真人三级小视频在线观看| 1024手机看黄色片| av福利片在线观看| 国产精品精品国产色婷婷| 午夜久久久久精精品| 午夜免费成人在线视频| 麻豆成人午夜福利视频| 激情在线观看视频在线高清| av在线天堂中文字幕| 中文字幕最新亚洲高清| 午夜福利欧美成人| e午夜精品久久久久久久| 成人特级黄色片久久久久久久| 国内毛片毛片毛片毛片毛片| 窝窝影院91人妻| 亚洲片人在线观看| 国产单亲对白刺激| 好男人电影高清在线观看| 99久久无色码亚洲精品果冻| 国产亚洲精品一区二区www| 久久久久久久久久黄片| 亚洲国产精品久久男人天堂| av中文乱码字幕在线| 午夜福利视频1000在线观看| 免费在线观看视频国产中文字幕亚洲| 国产一区二区激情短视频| 欧洲精品卡2卡3卡4卡5卡区| 亚洲自拍偷在线| 99在线视频只有这里精品首页| 成人国产综合亚洲| 国产一区二区三区在线臀色熟女| 久久国产精品人妻蜜桃| 国产真人三级小视频在线观看| 亚洲成人久久爱视频| 国语自产精品视频在线第100页| 九九热线精品视视频播放| 黄色丝袜av网址大全| 亚洲美女黄片视频| 国产美女午夜福利| 不卡一级毛片| 高清毛片免费观看视频网站| 国产精品99久久99久久久不卡| 一区二区三区国产精品乱码| 国产精品一区二区三区四区久久| av黄色大香蕉| 热99在线观看视频| 亚洲精品456在线播放app | 亚洲精品456在线播放app | 午夜福利成人在线免费观看| 18禁观看日本| 一本一本综合久久| 成人特级黄色片久久久久久久| 性色av乱码一区二区三区2| 日日夜夜操网爽| 免费av毛片视频| 国产单亲对白刺激| 国产野战对白在线观看| 三级毛片av免费| 全区人妻精品视频| 久久精品91无色码中文字幕| 亚洲自偷自拍图片 自拍| 久久香蕉国产精品| 亚洲天堂国产精品一区在线| 热99在线观看视频| 亚洲avbb在线观看| 亚洲乱码一区二区免费版| 午夜精品久久久久久毛片777| 亚洲精品一卡2卡三卡4卡5卡| 日韩欧美免费精品| 国产熟女xx| 久久精品影院6| 伦理电影免费视频| 久久这里只有精品中国| 久久久久国产一级毛片高清牌| 成人国产一区最新在线观看| 欧美日韩福利视频一区二区| 老汉色∧v一级毛片| 免费看十八禁软件| 在线观看66精品国产| 日本免费a在线| 99国产精品99久久久久| 长腿黑丝高跟| 夜夜躁狠狠躁天天躁| 国产蜜桃级精品一区二区三区| 国产精品亚洲av一区麻豆| 精品电影一区二区在线| 久久性视频一级片| 亚洲国产高清在线一区二区三| 国产精品久久久久久人妻精品电影| netflix在线观看网站| 99在线人妻在线中文字幕| 伦理电影免费视频| 亚洲美女视频黄频| 国产精品 欧美亚洲| av国产免费在线观看| 国产日本99.免费观看| av在线蜜桃| 色精品久久人妻99蜜桃| 免费av不卡在线播放| 叶爱在线成人免费视频播放| 国产精品 欧美亚洲| 悠悠久久av| 精品久久久久久久毛片微露脸| 狂野欧美白嫩少妇大欣赏| 一级毛片精品| 人妻夜夜爽99麻豆av| 他把我摸到了高潮在线观看| 久久亚洲真实| xxxwww97欧美| 99国产精品99久久久久| 精品电影一区二区在线| 床上黄色一级片| 最近在线观看免费完整版| 亚洲 欧美一区二区三区| 精品电影一区二区在线| 老汉色av国产亚洲站长工具| 精品一区二区三区四区五区乱码| 国产成人av激情在线播放| 亚洲精品在线美女| 国产精品免费一区二区三区在线| 禁无遮挡网站| 欧洲精品卡2卡3卡4卡5卡区| 国产精品国产高清国产av| 国产又色又爽无遮挡免费看| 精品久久久久久久末码| 亚洲在线观看片| 国产男靠女视频免费网站| 欧美日韩乱码在线| 美女扒开内裤让男人捅视频| 手机成人av网站| 在线观看一区二区三区| 日本a在线网址| 人妻久久中文字幕网| 国产精品98久久久久久宅男小说| 亚洲,欧美精品.| 亚洲人成电影免费在线| 欧美高清成人免费视频www| 老熟妇仑乱视频hdxx| 国产精品av久久久久免费| 中出人妻视频一区二区| av天堂中文字幕网| 99热只有精品国产| 国产亚洲精品久久久com| 中文字幕久久专区| 国产精品久久久久久亚洲av鲁大| 18禁美女被吸乳视频| 亚洲精品乱码久久久v下载方式 | 成人特级黄色片久久久久久久| 日韩三级视频一区二区三区| 一级作爱视频免费观看| 国产aⅴ精品一区二区三区波| 久久久久久九九精品二区国产| 综合色av麻豆| 欧美日韩亚洲国产一区二区在线观看| 午夜福利在线观看免费完整高清在 | 国产欧美日韩一区二区三| 操出白浆在线播放| 久久精品国产综合久久久| 人妻夜夜爽99麻豆av| 午夜福利免费观看在线| 夜夜夜夜夜久久久久| 国产免费男女视频| 2021天堂中文幕一二区在线观| 51午夜福利影视在线观看| 蜜桃久久精品国产亚洲av| 曰老女人黄片| 一二三四社区在线视频社区8| 国产精品亚洲av一区麻豆| 手机成人av网站| 宅男免费午夜| 一边摸一边抽搐一进一小说| 天堂av国产一区二区熟女人妻| 精品人妻1区二区| 最近最新中文字幕大全免费视频| 校园春色视频在线观看| 国产一级毛片七仙女欲春2| 琪琪午夜伦伦电影理论片6080| 精品一区二区三区四区五区乱码| 国产熟女xx| 亚洲av免费在线观看| 久久久国产成人精品二区| 在线观看免费视频日本深夜| 观看美女的网站| 国产精品野战在线观看| 色综合亚洲欧美另类图片| 免费在线观看亚洲国产| 国产精品1区2区在线观看.| 日本 欧美在线| 亚洲午夜理论影院| 欧美黑人欧美精品刺激| 中出人妻视频一区二区| ponron亚洲| 日韩高清综合在线| 亚洲专区字幕在线| 麻豆国产97在线/欧美| www.熟女人妻精品国产| 国产野战对白在线观看| av女优亚洲男人天堂 | 久久亚洲真实| 老司机深夜福利视频在线观看| 久久久久久国产a免费观看| 久久人妻av系列| 久久久成人免费电影| 精品久久蜜臀av无| 99国产极品粉嫩在线观看| 欧美成狂野欧美在线观看| 亚洲欧美精品综合一区二区三区| 男女之事视频高清在线观看| 99热精品在线国产| 精品国产美女av久久久久小说| 婷婷精品国产亚洲av在线| 夜夜爽天天搞| 欧美日韩瑟瑟在线播放| 精品免费久久久久久久清纯| 一区二区三区国产精品乱码| 久久久久久国产a免费观看| 淫妇啪啪啪对白视频| 丰满的人妻完整版| 亚洲欧美精品综合久久99| 欧美日本亚洲视频在线播放| 国内精品久久久久久久电影| 亚洲成人久久性| 嫁个100分男人电影在线观看| 国产精品乱码一区二三区的特点| 日本免费a在线| 两性午夜刺激爽爽歪歪视频在线观看| 免费大片18禁| 国产免费男女视频| 露出奶头的视频| 很黄的视频免费| 免费一级毛片在线播放高清视频| 香蕉av资源在线| 亚洲av电影不卡..在线观看| 日韩人妻高清精品专区| 18禁裸乳无遮挡免费网站照片| 国产免费男女视频| 天堂√8在线中文| 国产又黄又爽又无遮挡在线| 宅男免费午夜| 精品久久久久久久人妻蜜臀av| 日韩欧美免费精品| 变态另类成人亚洲欧美熟女| 在线观看日韩欧美| 天天躁狠狠躁夜夜躁狠狠躁| 国产久久久一区二区三区| 五月玫瑰六月丁香| 久久精品国产综合久久久| 成人午夜高清在线视频| 成年女人看的毛片在线观看| 无人区码免费观看不卡| 国产又色又爽无遮挡免费看| 色尼玛亚洲综合影院| 五月伊人婷婷丁香| 99久久精品国产亚洲精品| 亚洲国产高清在线一区二区三| 99国产精品一区二区蜜桃av| 小蜜桃在线观看免费完整版高清| 日韩欧美三级三区| 中文字幕av在线有码专区| 亚洲欧美一区二区三区黑人| 九九在线视频观看精品| 久99久视频精品免费| www.自偷自拍.com| 99热这里只有精品一区 | 男女视频在线观看网站免费| 免费在线观看影片大全网站| 国产成人欧美在线观看| 久久天堂一区二区三区四区| 亚洲av中文字字幕乱码综合| 搡老妇女老女人老熟妇| 香蕉久久夜色| 噜噜噜噜噜久久久久久91| 夜夜躁狠狠躁天天躁| 国产伦精品一区二区三区视频9 | 91av网站免费观看| 国产伦精品一区二区三区四那| 99精品欧美一区二区三区四区| 国产精品永久免费网站| 亚洲国产看品久久| 91麻豆av在线| 在线视频色国产色| 97超级碰碰碰精品色视频在线观看| 伊人久久大香线蕉亚洲五| 午夜精品久久久久久毛片777| 国产99白浆流出| 美女cb高潮喷水在线观看 | 日韩av在线大香蕉| 韩国av一区二区三区四区| 精品久久久久久久毛片微露脸| 一级毛片高清免费大全| 在线免费观看的www视频| 国内久久婷婷六月综合欲色啪| 国产高清激情床上av| 女人被狂操c到高潮| 久久久国产欧美日韩av| 美女高潮的动态| 男女午夜视频在线观看| 热99re8久久精品国产| 国产精品综合久久久久久久免费| 1024手机看黄色片| 久久精品91蜜桃| 一本久久中文字幕| 亚洲人成网站在线播放欧美日韩| 国产成人影院久久av| 全区人妻精品视频| 欧美成狂野欧美在线观看| 国产一级毛片七仙女欲春2| 久久久久九九精品影院| 国产精品99久久99久久久不卡| 亚洲欧美日韩卡通动漫| 黄色日韩在线| 美女 人体艺术 gogo| 国产高清激情床上av| 国产伦精品一区二区三区四那| 欧美zozozo另类| 久久热精品热| 久久精品国产亚洲av天美| 久久久久久国产a免费观看| 伦理电影大哥的女人| 午夜爱爱视频在线播放| 在线观看一区二区三区| a级一级毛片免费在线观看| 免费搜索国产男女视频| 久久精品人妻少妇| 国产在线一区二区三区精 | 能在线免费观看的黄片| 日韩av不卡免费在线播放| 中文乱码字字幕精品一区二区三区 | 亚洲精品456在线播放app| 日韩精品青青久久久久久| 51国产日韩欧美| 欧美又色又爽又黄视频| 一边摸一边抽搐一进一小说| 久久精品91蜜桃| 一本一本综合久久| 男的添女的下面高潮视频| 国产淫片久久久久久久久| 91久久精品电影网| 最近的中文字幕免费完整| 2022亚洲国产成人精品| 日本黄色片子视频| 精华霜和精华液先用哪个| 久久久久久久国产电影| 99久久精品热视频| 老女人水多毛片| 国产亚洲91精品色在线| 国产激情偷乱视频一区二区| 成年女人永久免费观看视频| av在线亚洲专区| 日日摸夜夜添夜夜爱| 精品国产露脸久久av麻豆 | 国产亚洲最大av| kizo精华| 搡老妇女老女人老熟妇| 精品国产一区二区三区久久久樱花 | 国产又色又爽无遮挡免| 午夜老司机福利剧场| 男女啪啪激烈高潮av片| 精品久久久久久久久久久久久| 变态另类丝袜制服| 97超碰精品成人国产| 免费观看人在逋| 黄色配什么色好看| 国产免费视频播放在线视频 | h日本视频在线播放| 国模一区二区三区四区视频| 亚洲国产高清在线一区二区三| 欧美色视频一区免费| 神马国产精品三级电影在线观看| 久久久国产成人精品二区| 91aial.com中文字幕在线观看| 欧美成人免费av一区二区三区| 婷婷色综合大香蕉| 尤物成人国产欧美一区二区三区| 国产精品人妻久久久影院| 一级毛片aaaaaa免费看小| 我要看日韩黄色一级片| 欧美人与善性xxx| 丝袜美腿在线中文| 九九在线视频观看精品| 国产人妻一区二区三区在| 人人妻人人澡欧美一区二区| 国产91av在线免费观看| 国产欧美另类精品又又久久亚洲欧美| 亚洲av中文字字幕乱码综合| 国产黄色小视频在线观看| av福利片在线观看| 精品人妻熟女av久视频| 国产私拍福利视频在线观看| 国产精品乱码一区二三区的特点| 亚洲人与动物交配视频| 一本—道久久a久久精品蜜桃钙片 精品乱码久久久久久99久播 | a级毛色黄片| 国产精品一区二区三区四区久久| 白带黄色成豆腐渣| 建设人人有责人人尽责人人享有的 | 国内精品宾馆在线| 亚洲欧洲国产日韩| 欧美日韩国产亚洲二区| 国产人妻一区二区三区在| 七月丁香在线播放| 岛国毛片在线播放| 国产精品熟女久久久久浪| 亚洲自拍偷在线| 国产av一区在线观看免费| 久久久久久久午夜电影|