亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS開發使用UITableView制作N級下拉菜單的示例

2020-07-26 02:31:19
字體:
來源:轉載
供稿:網友

前言

demo地址:  https://github.com/963527512/MultilayerMenu, 如果有更好的辦法, 請留言 前段時間在做項目的時候, 遇到了一個N級下拉菜單的需求, 可無限層級的展開和閉合, 下面是效果圖

其中每一個UITableViewCell左右兩部分擁有不同的功能

  1. 左半部分我放了一個按鈕, 用來控制每個選項的選中狀態
  2. 右半部分控制菜單的展開和閉合

下面是我在做這個功能時的思路, 使用的是MVC

創建控制器, 并添加數據

第一步, 創建一個新的項目, 并添加幾個類

LTMenuItemViewController: 繼承自UITableViewController, 多層菜單界面

LTMenuItem: 繼承自 NSObject, 多層菜單的選項模型, 其中有兩個屬性

  1.  name : 選項的名稱
  2. subs : 選項的子層級數據
#import <Foundation/Foundation.h>@interface LTMenuItem : NSObject/** 名字 */@property (nonatomic, strong) NSString *name;/** 子層 */@property (nonatomic, strong) NSArray<LTMenuItem *> *subs;@end

LTMenuItemCell: 繼承自: UITableViewCell, 多層菜單的選項cell 添加數據源文件, 存放的就是需要展示的菜單數據, 項目中應從網絡中獲取, 這里為了方便, 使用文件的形式

 第二步, 在LTMenuItemViewController中, 設置tableView的數據源和cell

效果圖如下:

 

具體代碼如下, 其中數組轉模型使用的第三方庫 MJExtension

#import "LTMenuItemViewController.h"#import "LTMenuItem.h"#import "LTMenuItemCell.h"#import <MJExtension/MJExtension.h>@interface LTMenuItemViewController ()/** 菜單項 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *menuItems;@end@implementation LTMenuItemViewControllerstatic NSString *LTMenuItemId = @"LTMenuItemCell";- (void)viewDidLoad {  [super viewDidLoad];    [self setup];    [self setupTableView];}- (void)didReceiveMemoryWarning {  [super didReceiveMemoryWarning];  // Dispose of any resources that can be recreated.}#pragma mark - < 基本設置 >- (void)setup{  self.title = @"多級菜單";    NSString *filePath = [[NSBundle mainBundle] pathForResource:@"a" ofType:@"plist"];  NSArray *date = [NSArray arrayWithContentsOfFile:filePath];  self.menuItems = [LTMenuItem mj_objectArrayWithKeyValuesArray:date];  self.tableView.separatorStyle = UITableViewCellSelectionStyleNone;  self.tableView.rowHeight = 45;  [self.tableView registerClass:[LTMenuItemCell class] forCellReuseIdentifier:LTMenuItemId];}#pragma mark - Table view data source- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {  return 1;}- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {  return self.menuItems.count;}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {  LTMenuItemCell *cell = [tableView dequeueReusableCellWithIdentifier:LTMenuItemId forIndexPath:indexPath];  cell.menuItem = self.menuItems[indexPath.row];  return cell;}

第三步, 設置選項模型, 添加輔助屬性

LTMenuItem 類添加幾個輔助屬性, 用于表示選中和展開閉合

  1.  isSelected : 用于表示選項的選中狀態
  2. isUnfold : 用來表示本層級的展開和閉合狀態
  3. isCanUnfold : 用于表示本層級是否能夠展開, 只有當 subs 屬性的個數不為0時, 才取值 YES
  4. index : 表示當前的層級, 第一層的值為0
#import <Foundation/Foundation.h>@interface LTMenuItem : NSObject/** 名字 */@property (nonatomic, strong) NSString *name;/** 子層 */@property (nonatomic, strong) NSArray<LTMenuItem *> *subs;#pragma mark - < 輔助屬性 >/** 是否選中 */@property (nonatomic, assign) BOOL isSelected;/** 是否展開 */@property (nonatomic, assign) BOOL isUnfold;/** 是否能展開 */@property (nonatomic, assign) BOOL isCanUnfold;/** 當前層級 */@property (nonatomic, assign) NSInteger index;@end
#import "LTMenuItem.h"@implementation LTMenuItem/** 指定subs數組中存放LTMenuItem類型對象 */+ (NSDictionary *)mj_objectClassInArray{  return @{@"subs" : [LTMenuItem class]};}/** 判斷是否能夠展開, 當subs中有數據時才能展開 */- (BOOL)isCanUnfold{  return self.subs.count > 0;}@end

第四步, 設置展開閉合時, 需要顯示的數據

在控制器 LTMenuItemViewController 中, 當前展示的數據是數組 menuItems , 此時并不好控制應該展示在 tableView 中的數據, 所以添加一個新的屬性, 用來包含需要展示的數據

@interface LTMenuItemViewController () /** 菜單項 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *menuItems;/** 當前需要展示的數據 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *latestShowMenuItems;@end

其中 latestShowMenuItems 就是展示在tableView中的數據

使用懶加載, 創建 latestShowMenuItems

- (NSMutableArray<LTMenuItem *> *)latestShowMenuItems{  if (!_latestShowMenuItems) {    self.latestShowMenuItems = [[NSMutableArray alloc] init];  }  return _latestShowMenuItems;}

修改數據源方法, 使用 latestShowMenuItems 替換 menuItems

#pragma mark - Table view data source- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {  return 1;}- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {  return self.latestShowMenuItems.count;}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {  LTMenuItemCell *cell = [tableView dequeueReusableCellWithIdentifier:LTMenuItemId forIndexPath:indexPath];  cell.menuItem = self.latestShowMenuItems[indexPath.row];  return cell;}

此時我們只需要控制 latestShowMenuItems 中包含的數據, 就可以控制頁面的展示, 而 menuItems 中的數據不需要增加和減少

 第五步, 控制 latestShowMenuItems 中數據的方法

現在, latestShowMenuItems 中沒有數據, 所以界面初始化后將不會展示任何數據

我們接下來就在 latestShowMenuItems 中添加初始化界面時需要展示的數據, 并設置層級為0

- (void)setupRowCount{  // 添加需要展示項, 并設置層級, 初始化0  [self setupRouCountWithMenuItems:self.menuItems index:0];}/** 將需要展示的選項添加到latestShowMenuItems中 */- (void)setupRouCountWithMenuItems:(NSArray<LTMenuItem *> *)menuItems index:(NSInteger)index{  for (int i = 0; i < menuItems.count; i++) {    LTMenuItem *item = menuItems[i];    // 設置層級    item.index = index;    // 將選項添加到數組中    [self.latestShowMenuItems addObject:item];  }}

第六步, 通過tableView代理中cell的點擊方法, 處理菜單的展開閉合操作

通過 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath 方法, 處理菜單的展開閉合操作

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{  // 取出點擊的選項  LTMenuItem *menuItem = self.latestShowMenuItems[indexPath.row];  // 判斷是否能夠展開, 不能展開立即返回, 不錯任何處理  if (!menuItem.isCanUnfold) return;  // 設置展開閉合  menuItem.isUnfold = !menuItem.isUnfold;  // 刷新列表  [self.tableView reloadData];}

在這里, 根據被點擊數據能否展開, 修改了對應的 isUnfold 屬性, 并刷新界面

但此時由于 latestShowMenuItems 中數據沒有數量變化, 所以子層級并不能顯示出來

所以我們需要對 latestShowMenuItems 中的數據進行修改

我們在這里修改第五步中的兩個方法, 如下所示

#pragma mark - < 添加可以展示的選項 >- (void)setupRowCount{  // 清空當前所有展示項  [self.latestShowMenuItems removeAllObjects];    // 重新添加需要展示項, 并設置層級, 初始化0  [self setupRouCountWithMenuItems:self.menuItems index:0];}/** 將需要展示的選項添加到latestShowMenuItems中, 此方法使用遞歸添加所有需要展示的層級到latestShowMenuItems中 @param menuItems 需要添加到latestShowMenuItems中的數據 @param index 層級, 即當前添加的數據屬于第幾層 */- (void)setupRouCountWithMenuItems:(NSArray<LTMenuItem *> *)menuItems index:(NSInteger)index{  for (int i = 0; i < menuItems.count; i++) {    LTMenuItem *item = menuItems[i];    // 設置層級    item.index = index;    // 將選項添加到數組中    [self.latestShowMenuItems addObject:item];    // 判斷該選項的是否能展開, 并且已經需要展開    if (item.isCanUnfold && item.isUnfold) {      // 當需要展開子集的時候, 添加子集到數組, 并設置子集層級      [self setupRouCountWithMenuItems:item.subs index:index + 1];    }  }}

在一開始, 先清空 latestShowMenuItems 中的數據, 然后添加第一層數據

在添加第一層數據的時候, 對每一個數據進行判斷, 判斷是否能展開, 并且是否已經展開

如果展開, 添加子類到數組, 這里用遞歸層層遞進, 最后將每一層子類展開的數據全部添加到 latestShowMenuItems 中, 同時設置了每一層數據的層級屬性 index

此時 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath 方法, 需要做如下修改

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{  // 取出點擊的選項  LTMenuItem *menuItem = self.latestShowMenuItems[indexPath.row];  // 判斷是否能夠展開, 不能展開立即返回, 不錯任何處理  if (!menuItem.isCanUnfold) return;  // 設置展開閉合  menuItem.isUnfold = !menuItem.isUnfold;  // 修改latestShowMenuItems中數據  [self setupRowCount];  // 刷新列表  [self.tableView reloadData];}

這時, 我們已經可以看到界面上有如下效果

 

第七步, 添加展開閉合的伸縮動畫效果

首先添加一個屬性 oldShowMenuItems , 用來記錄改變前 latestShowMenuItems 中的數據

@interface LTMenuItemViewController ()/** 菜單項 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *menuItems;/** 當前需要展示的數據 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *latestShowMenuItems;/** 以前需要展示的數據 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *oldShowMenuItems;@end

修改 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath 方法, 添加展開動畫效果

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{  LTMenuItem *menuItem = self.latestShowMenuItems[indexPath.row];  if (!menuItem.isCanUnfold) return;    // 記錄改變之前的數據  self.oldShowMenuItems = [NSMutableArray arrayWithArray:self.latestShowMenuItems];    // 設置展開閉合  menuItem.isUnfold = !menuItem.isUnfold;  // 更新被點擊cell的箭頭指向  [self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:(UITableViewRowAnimationAutomatic)];    // 設置需要展開的新數據  [self setupRowCount];    // 判斷老數據和新數據的數量, 來進行展開和閉合動畫  // 定義一個數組, 用于存放需要展開閉合的indexPath  NSMutableArray<NSIndexPath *> *indexPaths = @[].mutableCopy;    // 如果 老數據 比 新數據 多, 那么就需要進行閉合操作  if (self.oldShowMenuItems.count > self.latestShowMenuItems.count) {    // 遍歷oldShowMenuItems, 找出多余的老數據對應的indexPath    for (int i = 0; i < self.oldShowMenuItems.count; i++) {      // 當新數據中 沒有對應的item時      if (![self.latestShowMenuItems containsObject:self.oldShowMenuItems[i]]) {        NSIndexPath *subIndexPath = [NSIndexPath indexPathForRow:i inSection:indexPath.section];        [indexPaths addObject:subIndexPath];      }    }    // 移除找到的多余indexPath    [self.tableView deleteRowsAtIndexPaths:indexPaths withRowAnimation:(UITableViewRowAnimationTop)];  }else {    // 此時 新數據 比 老數據 多, 進行展開操作    // 遍歷 latestShowMenuItems, 找出 oldShowMenuItems 中沒有的選項, 就是需要新增的indexPath    for (int i = 0; i < self.latestShowMenuItems.count; i++) {      if (![self.oldShowMenuItems containsObject:self.latestShowMenuItems[i]]) {        NSIndexPath *subIndexPath = [NSIndexPath indexPathForRow:i inSection:indexPath.section];        [indexPaths addObject:subIndexPath];      }    }    // 插入找到新添加的indexPath    [self.tableView insertRowsAtIndexPaths:indexPaths withRowAnimation:(UITableViewRowAnimationTop)];  }}

通過判斷新老數據的數量, 已經對應的位置, 進行刪除和插入操作, 就可以添加對應的動畫效果

此時, 效果如下:

 

第八步, 選項的選中效果

我在cell的左半部分添加了一個半個cell寬的透明按鈕, 并設置了一個代理方法

當點擊透明按鈕時, 調用代理方法, 修改cell對應的 LTMenuItemisSelected 的值, 來控制選中狀態

在控制器中指定代理, 并實現代理方法

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {  LTMenuItemCell *cell = [tableView dequeueReusableCellWithIdentifier:LTMenuItemId forIndexPath:indexPath];  cell.menuItem = self.latestShowMenuItems[indexPath.row];  cell.delegate = self;  return cell;}
#pragma mark - < LTMenuItemCellDelegate >- (void)cell:(LTMenuItemCell *)cell didSelectedBtn:(UIButton *)sender{  cell.menuItem.isSelected = !cell.menuItem.isSelected;  [self.tableView reloadData];}

效果如下:

 

第九步, 使用遞歸進行 全選和反選 操作

首先我們在導航條右側添加 全選 按鈕, 并實現對應的點擊方法

#pragma mark - < 點擊事件 >- (void)allBtnClick:(UIButton *)sender{  sender.selected = !sender.selected;    [self selected:sender.selected menuItems:self.menuItems];}/** 取消或選擇, 某一數值中所有的選項, 包括子層級 @param selected 是否選中 @param menuItems 選項數組 */- (void)selected:(BOOL)selected menuItems:(NSArray<LTMenuItem *> *)menuItems{  for (int i = 0; i < menuItems.count; i++) {    LTMenuItem *menuItem = menuItems[i];    menuItem.isSelected = selected;    if (menuItem.isCanUnfold) {      [self selected:selected menuItems:menuItem.subs];    }  }  [self.tableView reloadData];}

上述的第二個方法, 就是修改對應數組中所有的數據及子集的選中狀態

同時修改該cell的代理方法 - (void)cell:(LTMenuItemCell *)cell didSelectedBtn:(UIButton *)sender 的實現

#pragma mark - < LTMenuItemCellDelegate >- (void)cell:(LTMenuItemCell *)cell didSelectedBtn:(UIButton *)sender{  cell.menuItem.isSelected = !cell.menuItem.isSelected;  // 修改按鈕狀態  self.allBtn.selected = NO;  [self.tableView reloadData];}

最終效果如下:

 

第十步, 使用已選擇數據

這里主要是拿到所有已經選中的數據, 并進行操作

我只進行了打印操作, 如果需要, 可以自己修改

首先添加一個屬性 selectedMenuItems , 用于存儲已選數據

然后通過下列代碼可以獲取所有已經選中的數據

@interface LTMenuItemViewController () <LTMenuItemCellDelegate>/** 菜單項 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *menuItems;/** 當前需要展示的數據 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *latestShowMenuItems;/** 以前需要展示的數據 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *oldShowMenuItems;/** 已經選中的選項, 可用于回調 */@property (nonatomic, strong) NSMutableArray<LTMenuItem *> *selectedMenuItems;/** 全選按鈕 */@property (nonatomic, strong) UIButton *allBtn;@end
#pragma mark - < 選中數據 >- (void)printSelectedMenuItems:(UIButton *)sender{  [self.selectedMenuItems removeAllObjects];  [self departmentsWithMenuItems:self.menuItems];  NSLog(@"這里是全部選中數據/n%@", self.selectedMenuItems);}/** 獲取選中數據 */- (void)departmentsWithMenuItems:(NSArray<LTMenuItem *> *)menuItems{  for (int i = 0; i < menuItems.count; i++) {    LTMenuItem *menuItem = menuItems[i];    if (menuItem.isSelected) {      [self.selectedMenuItems addObject:menuItem];    }    if (menuItem.subs.count) {      [self departmentsWithMenuItems:menuItem.subs];    }  }}

通過遞歸, 一層層拿到所有已經選擇的選項, 并進行打印操作

如果需要另外處理拿到的數據 只需要修改 printSelectedMenuItems 方法中的 NSLog(@"這里是全部選中數據/n%@", self.selectedMenuItems); 即可

demo地址: https://github.com/963527512/MultilayerMenu

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
大胆欧美人体视频| 欧美乱妇40p| 国产亚洲日本欧美韩国| 欧美精品做受xxx性少妇| 中文字幕av一区中文字幕天堂| 国产日本欧美在线观看| 欧洲美女免费图片一区| 亚洲欧洲黄色网| 在线观看久久av| 亚洲女人被黑人巨大进入al| 亚洲欧美精品一区二区| 欧美怡红院视频一区二区三区| 日韩高清av一区二区三区| 日韩av在线精品| 国产成人啪精品视频免费网| 亚洲一区中文字幕在线观看| 97国产真实伦对白精彩视频8| 8090成年在线看片午夜| 理论片在线不卡免费观看| 中文字幕精品一区二区精品| 国产视频精品在线| 国内精品小视频在线观看| 欧美一级免费视频| 日韩成人中文电影| 成人黄色av网站| 日韩欧美在线免费观看| 91av在线视频观看| 国产精品大片wwwwww| 亚洲国产日韩一区| 国产亚洲精品一区二555| 欧美大奶子在线| 蜜臀久久99精品久久久久久宅男| 久久精品国产一区二区电影| 国产精品一区二区3区| 91精品国产综合久久久久久久久| 国产精品自拍网| 69久久夜色精品国产69乱青草| 欧美激情xxxxx| 国产精品久久久久久久7电影| 欧美性在线视频| 国内免费久久久久久久久久久| 国产美女91呻吟求| 欧美精品免费在线| 亚洲成人激情小说| 日韩中文字幕亚洲| 欧美午夜丰满在线18影院| 国产精品精品久久久久久| 日本19禁啪啪免费观看www| 爽爽爽爽爽爽爽成人免费观看| 亚洲第一精品夜夜躁人人躁| 欧美日韩在线观看视频| 欧美日韩国产一区中文午夜| 北条麻妃在线一区二区| 欧美情侣性视频| 国产美女久久久| 国产人妖伪娘一区91| 亚洲аv电影天堂网| 在线视频欧美性高潮| 久久香蕉国产线看观看av| 国产精品视频久久久久| 亚洲va欧美va国产综合剧情| 亚洲自拍偷拍网址| 欧美精品少妇videofree| 国产精品一区av| 国产精品www网站| 最近的2019中文字幕免费一页| 2019亚洲男人天堂| 久久久视频免费观看| 欧美性videos高清精品| 91精品免费久久久久久久久| 国产国语刺激对白av不卡| 精品丝袜一区二区三区| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美性xxxxhd| 亚洲国产一区二区三区四区| 久久久久久国产精品三级玉女聊斋| 亚洲精品福利免费在线观看| 26uuu国产精品视频| 日韩av中文在线| 91午夜在线播放| 日本老师69xxx| 日韩电影中文字幕在线观看| 国产欧美一区二区三区在线| 日韩中文视频免费在线观看| 国产精品jizz在线观看麻豆| 亚洲成人精品久久久| 久久久精品欧美| 国产精品jizz在线观看麻豆| 国产精品高精视频免费| 欧美日韩国产91| 亚洲精品在线看| 欧美性猛交xxxx偷拍洗澡| 欧美国产日韩一区二区三区| 高清亚洲成在人网站天堂| 91久久精品久久国产性色也91| 日韩精品免费看| 高清欧美性猛交xxxx| 亚洲一区二区久久久| 日韩精品极品视频| 91产国在线观看动作片喷水| 亚洲天堂日韩电影| 精品性高朝久久久久久久| 亚洲精品国产精品乱码不99按摩| 精品久久久久国产| 人人爽久久涩噜噜噜网站| 91免费视频国产| 97免费在线视频| 91精品成人久久| 久久精品欧美视频| 国产精品久久久久久久7电影| 亚洲女人初尝黑人巨大| 中文字幕在线观看亚洲| www.色综合| 日韩a**站在线观看| 亚洲精品国精品久久99热| 中日韩午夜理伦电影免费| 日韩中文字幕精品视频| 在线观看欧美日韩国产| 日韩亚洲欧美中文在线| 国产福利精品av综合导导航| 久久视频在线看| 久久69精品久久久久久久电影好| 高清欧美性猛交xxxx黑人猛交| 国内精品视频在线| 中文一区二区视频| 精品久久久久久中文字幕大豆网| 韩国福利视频一区| 亚洲四色影视在线观看| 色老头一区二区三区在线观看| 国产噜噜噜噜久久久久久久久| 麻豆一区二区在线观看| www高清在线视频日韩欧美| 欧美香蕉大胸在线视频观看| 日本道色综合久久影院| 亚洲激情视频在线播放| 欧美极品欧美精品欧美视频| 最近中文字幕mv在线一区二区三区四区| 国自产精品手机在线观看视频| 最新69国产成人精品视频免费| 亚洲国产精品va在看黑人| 77777少妇光屁股久久一区| 亚洲精品国产精品自产a区红杏吧| 亚洲最新在线视频| 国产成人av网址| 美女视频黄免费的亚洲男人天堂| 日本精品性网站在线观看| 欧美亚洲成人网| 亚洲精品在线91| 亚洲毛片在线免费观看| 日韩日本欧美亚洲| 国产亚洲福利一区| 国产精品视频大全| 97婷婷涩涩精品一区| 性欧美xxxx视频在线观看| 成人免费看吃奶视频网站| 亚洲精品一区中文| 国产欧美日韩精品丝袜高跟鞋| 69国产精品成人在线播放| 日韩欧美有码在线| www.亚洲一二| 精品久久久精品| 久久国产精品亚洲| 成人网欧美在线视频| 亚洲精品99久久久久中文字幕|