精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

裂開!WebStorm 把我心態搞炸了

開發 前端
使用 webStorm 已經大半年了,整體使用下來的感受就是,這個破玩意兒的配置成本真的太高了。每次搞配置都要搞好久好久。有的配置找半天也找不到在哪里搞的,垃圾 webStorm!心態已炸!

今天被 webStorm 把我心態搞炸了。

情況是這樣的,我發現 webStorm 的 JSX 粘貼進來一段代碼,他就會自動把我以前的代碼格式化掉。表現如下:

然后呢,我就非常不想要這個自動格式化的功能。所以就想著在哪里配置一下,把這個自動格式化的功能給禁用掉。

結果,就為了這么個破玩意兒,浪費了整整兩個小時。試了好多種方式,都沒有用!!!

比如這種,Setting -> Editor -> General -> Smart Keys,然后把 Reformat on paste 設置為 None。

最后才找到是這個破玩意兒在這里配置的。

使用 webStorm 已經大半年了,整體使用下來的感受就是,這個破玩意兒的配置成本真的太高了。每次搞配置都要搞好久好久。有的配置找半天也找不到在哪里搞的,垃圾 webStorm!心態已炸!!!

上面是純吐槽部分,這篇文章其實主要是跟大家分享一下如何在 Next.js 中引入 shadcn/ui 這個組件庫。

下圖是本文案例中,利用 shadcn/ui 實現 dark 模式切換的效果。

一、shadcn/ui 介紹

shadcn/ui 是最近幾年爆火的一個 UI 組件庫。如圖所示,他的 star 已經達到了 74.5K,這里最關鍵的是,去年的這個時候,他只有大概 35K 左右。一年時間漲了接近一倍。

這個流行速度,表示 shadcn/ui 正在快速被很多人接受。因此,我也很想去試試這個組件庫。就在新的項目中引入了。使用下來的整體感受就是,這個 UI 組件庫的上手陳本,遠比我想象中的要高。 雖然說,用熟練了之后他確實很好用,不過這個上手成本與反常的不適應感,我估計也勸退了一些想要嘗試他的小伙伴。

因此,我就專門寫一篇文章,給大家分享一下 shadcn/ui 的一些關鍵點。

嚴格上來說,shadcn/ui 并不是一個組件庫。因為我們可以只復制其中的某一個組件到代碼里,單獨使用這個一個組件。

shadcn/ui 建立在 RadixUI + Tailwincss 之上。目前支持 Next.js、Gatsby、Vite、Remix、Astro、Laravel、Manual。由于他是來自于 vercel 成員 shadcn 的開源作品,因此目前在 Next.js 應用是最廣泛的。

?

因此,shadcn/ui 的快速發展,也意味著 Next.js 的發展速度非常之快。特別是最近兩年的增量發展都聚焦在出海項目上,也促進了 Next.js 和 shadcn/ui 的火爆

二、怪異的引入方式

由于 shadcn/ui 的樣式,與 tailwindcss 息息相關。因此,在使用 shadcn/ui 之前,你需要確保你有 tailwindcss 的使用經驗,這樣才能更好的理解和使用 shadcn/ui,否則,你在使用的過程中,會有比較強的不適應感。

在 Next.js 的項目中執行如下指令,可以準備好 shadcn/ui 的使用環境。在初始化之前,你需要確保你的項目中,已經準備好了 tailwindcss。

npx shadcn@latest init
Which style would you like to use? ? New York
Which color would you like to use as base color? ? Zinc
Do you want to use CSS variables for colors? ? no / yes

安裝的過程中,我們需要選擇樣式風格 New York,以及主題色。最后是否選擇使用 css 變量,選擇 yes。

我們可以在自定義主題的面板中,觀察主題色的樣式,例如 Zinc 的風格以黑白色為主。如下所示。

你也可以選擇玫瑰紅 rose。

如果我們執行如下執行,則可以直接基于默認選擇結果 New York Zinc Yes 來初始化執行環境。

npx shadcn@latest init -d

這里需要特別注意的是,實際上初始環境的準備,就是在添加 tailwindcss 和組件相關的配置。因此執行這條指令之后,會對本地的一些配置文件進行一些更改。

首先是新增了 components.json。里面記錄了 shadcn/ui 相關的配置項,例如,是否支持 RSC,以及組件的別名配置。

{
  "$schema": "https://ui.shadcn.com/schema.json",
  "style": "new-york",
  "rsc": true,
  "tsx": true,
  "tailwind": {
    "config": "tailwind.config.ts",
    "css": "src/app/globals.css",
    "baseColor": "zinc",
    "cssVariables": true,
    "prefix": ""
  },
  "aliases": {
    "components": "@/components",
    "utils": "@/lib/utils",
    "ui": "@/components/ui",
    "lib": "@/lib",
    "hooks": "@/hooks"
  },
  "iconLibrary": "lucide"
}

然后是在 tailwind.config.ts 中,修改了主題配色,由于我這里選擇了基于 css 變量來實現主題切換,因此這里的配置主要是以配置 colors 為主。

colors: {
  background: 'hsl(var(--background))',
  foreground: 'hsl(var(--foreground))',
  card: {
    DEFAULT: 'hsl(var(--card))',
    foreground: 'hsl(var(--card-foreground))'
  },
  popover: {
    DEFAULT: 'hsl(var(--popover))',
    foreground: 'hsl(var(--popover-foreground))'
  },
  primary: {
    DEFAULT: 'hsl(var(--primary))',
    foreground: 'hsl(var(--primary-foreground))'
  },
  secondary: {
    DEFAULT: 'hsl(var(--secondary))',
    foreground: 'hsl(var(--secondary-foreground))'
  },
  muted: {
    DEFAULT: 'hsl(var(--muted))',
    foreground: 'hsl(var(--muted-foreground))'
  },
  accent: {
    DEFAULT: 'hsl(var(--accent))',
    foreground: 'hsl(var(--accent-foreground))'
  },
  destructive: {
    DEFAULT: 'hsl(var(--destructive))',
    foreground: 'hsl(var(--destructive-foreground))'
  },
  border: 'hsl(var(--border))',
  input: 'hsl(var(--input))',
  ring: 'hsl(var(--ring))',
  chart: {
    '1': 'hsl(var(--chart-1))',
    '2': 'hsl(var(--chart-2))',
    '3': 'hsl(var(--chart-3))',
    '4': 'hsl(var(--chart-4))',
    '5': 'hsl(var(--chart-5))'
  }
}

除此之外,他還會在 globals.css 中,新增一些樣式配置。這里主要是把 shadcn/ui 中所使用的 css 變量定義好。如果我們想要修改主題,就可以直接在這里修改就可以了。

@layer base {
  :root {
    --background: 0 0% 100%;
    --foreground: 240 10% 3.9%;
    --card: 0 0% 100%;
    --card-foreground: 240 10% 3.9%;
    --popover: 0 0% 100%;
    --popover-foreground: 240 10% 3.9%;
    --primary: 240 5.9% 10%;
    --primary-foreground: 0 0% 98%;
    --secondary: 240 4.8% 95.9%;
    --secondary-foreground: 240 5.9% 10%;
    --muted: 240 4.8% 95.9%;
    --muted-foreground: 240 3.8% 46.1%;
    --accent: 240 4.8% 95.9%;
    --accent-foreground: 240 5.9% 10%;
    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 5.9% 90%;
    --input: 240 5.9% 90%;
    --ring: 240 10% 3.9%;
    --chart-1: 12 76% 61%;
    --chart-2: 173 58% 39%;
    --chart-3: 197 37% 24%;
    --chart-4: 43 74% 66%;
    --chart-5: 27 87% 67%;
    --radius: 0.5rem;
  }
  .dark {
    --background: 240 10% 3.9%;
    --foreground: 0 0% 98%;
    --card: 240 10% 3.9%;
    --card-foreground: 0 0% 98%;
    --popover: 240 10% 3.9%;
    --popover-foreground: 0 0% 98%;
    --primary: 0 0% 98%;
    --primary-foreground: 240 5.9% 10%;
    --secondary: 240 3.7% 15.9%;
    --secondary-foreground: 0 0% 98%;
    --muted: 240 3.7% 15.9%;
    --muted-foreground: 240 5% 64.9%;
    --accent: 240 3.7% 15.9%;
    --accent-foreground: 0 0% 98%;
    --destructive: 0 62.8% 30.6%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 3.7% 15.9%;
    --input: 240 3.7% 15.9%;
    --ring: 240 4.9% 83.9%;
    --chart-1: 220 70% 50%;
    --chart-2: 160 60% 45%;
    --chart-3: 30 80% 55%;
    --chart-4: 280 65% 60%;
    --chart-5: 340 75% 55%;
  }
}

官方文檔提供了主題變換的操作面板。

配置好之后,可以點擊 Copy code 來把調整之后的主題代碼復制到這里來替換掉即可。

此時,我們還無法直接使用組件,每使用一個組件,我們都得單獨執行如下指令把對應的組件代碼代碼復制到項目中,才可以使用。

npx shadcn@latest add button

執行這條指令之后,我們會發現項目中的 src/components/ui 目錄下,多出來一個 button.tsx 組件。

之后,結合剛才默認的別名配置,我們就可以在其他組件中,使用如下方式,按照官方文檔的用法,使用 Button 組件。

import { Button } from "@/components/ui/button"
<Button variant="outline">Button</Button>

通過這個引入方式的介紹,我們就能很明顯的感受到,shadcn/ui 的使用前置知識比較多,并不是像 antd 那樣拿來即用。如果我們對 css 變量和 tailwindcss 不熟悉的話,可能還對這些前置知識不太理解。

三、實現 dark 模式切換

我們直接使用 next-themes 來實現 dark 模式。首先在項目中引入它。

yarn add next-themes

然后,我們需要單獨創建一個頂層的 Provider 組件來控制切換的邏輯。

components/theme-provider.tsx。

由于這些邏輯必須在客戶端環境才能執行,因此前面要加上 use client。

"use client"

import * as React from "react"
import { ThemeProvider as NextThemesProvider } from "next-themes"

export function ThemeProvider({
  children,
  ...props
}: React.ComponentProps<typeof NextThemesProvider>) {
  return <NextThemesProvider {...props}>{children}</NextThemesProvider>
}

然后我們就可以在項目根節點 app/layout.tsx 中,套一層我們剛才定義好的 Provider 組件。需要注意,這里直接是服務端組件,而不是客戶端組件。這也是我們需要單獨把 ThemeProvider 抽離出去的原因,是為了把客戶端邏輯單獨隔離出去,從而避免這個邏輯影響整個項目。

?

這里在 Next.js 中最重要,也是最常見的技巧。

import { ThemeProvider } from "@/components/theme-provider"
 
export default function RootLayout({ children }: RootLayoutProps) {
  return (
    <>
      <html lang="en" suppressHydrationWarning>
        <head />
        <body>
          <ThemeProvider
            attribute="class"
            defaultTheme="system"
            enableSystem
            disableTransitionOnChange
          >
            {children}
          </ThemeProvider>
        </body>
      </html>
    </>
  )
}

然后,我們單獨定義一個操作按鈕組件,該組件依賴于 Button 與 DropdownMenu,因此在定義之前,要單獨引入這兩個組件。

npx shadcn@latest add button
npx shadcn@latest add dropdown-menu

完整代碼如下:

'use client';

import { useTheme } from "next-themes"
import {Button} from "@/components/ui/button"
import {DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger} from '@/components/ui/dropdown-menu'

export default function ThemeToggleButton() {
  const {setTheme} = useTheme()
  return (
    <DropdownMenu>
      <DropdownMenuTrigger asChild>
        <Button variant='outline' size='icon'>
          <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor" className="size-6 scale-100 rotate-0 dark:-rotate-90 dark:scale-0">
            <path strokeLinecap="round" strokeLinejoin="round" d="M12 3v2.25m6.364.386-1.591 1.591M21 12h-2.25m-.386 6.364-1.591-1.591M12 18.75V21m-4.773-4.227-1.591 1.591M5.25 12H3m4.227-4.773L5.636 5.636M15.75 12a3.75 3.75 0 1 1-7.5 0 3.75 3.75 0 0 1 7.5 0Z"/>
          </svg>
          <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor" className="size-6 scale-0 rotate-90 dark:-rotate-90 dark:scale-100 absolute">
            <path strokeLinecap="round" strokeLinejoin="round" d="M21.752 15.002A9.72 9.72 0 0 1 18 15.75c-5.385 0-9.75-4.365-9.75-9.75 0-1.33.266-2.597.748-3.752A9.753 9.753 0 0 0 3 11.25C3 16.635 7.365 21 12.75 21a9.753 9.753 0 0 0 9.002-5.998Z" />
          </svg>
          <span className='sr-only'>Toggle theme</span>
        </Button>
      </DropdownMenuTrigger>

      <DropdownMenuContent align="end">
        <DropdownMenuItem notallow={() => setTheme("light")}>
          <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor" className="size-6">
            <path strokeLinecap="round" strokeLinejoin="round" d="M12 3v2.25m6.364.386-1.591 1.591M21 12h-2.25m-.386 6.364-1.591-1.591M12 18.75V21m-4.773-4.227-1.591 1.591M5.25 12H3m4.227-4.773L5.636 5.636M15.75 12a3.75 3.75 0 1 1-7.5 0 3.75 3.75 0 0 1 7.5 0Z"/>
          </svg>
          Light
        </DropdownMenuItem>
        <DropdownMenuItem notallow={() => setTheme("dark")}>
          <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor" className="size-6">
            <path strokeLinecap="round" strokeLinejoin="round" d="M21.752 15.002A9.72 9.72 0 0 1 18 15.75c-5.385 0-9.75-4.365-9.75-9.75 0-1.33.266-2.597.748-3.752A9.753 9.753 0 0 0 3 11.25C3 16.635 7.365 21 12.75 21a9.753 9.753 0 0 0 9.002-5.998Z" />
          </svg>
          Dark
        </DropdownMenuItem>
        <DropdownMenuItem notallow={() => setTheme("system")}>
          <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor" className="size-6">
            <path strokeLinecap="round" strokeLinejoin="round" d="M6 20.25h12m-7.5-3v3m3-3v3m-10.125-3h17.25c.621 0 1.125-.504 1.125-1.125V4.875c0-.621-.504-1.125-1.125-1.125H3.375c-.621 0-1.125.504-1.125 1.125v11.25c0 .621.504 1.125 1.125 1.125Z" />
          </svg>
          System
        </DropdownMenuItem>
      </DropdownMenuContent>
    </DropdownMenu>
  )
}

最終演示效果如下:

四、自定義樣式

有的時候,我們需要自定義樣式。這里需要注意的是,由于我們在項目中支持了 dark mode,因此,在這個基礎之上,我們并不能隨心所欲的使用 tailwindcss 的顏色,而是應該在剛才我們定義的主題色的基礎之上去使用。

@layer base {
  :root {
    --background: 0 0% 100%;
    --foreground: 240 10% 3.9%;
    --card: 0 0% 100%;
    --card-foreground: 240 10% 3.9%;
    --popover: 0 0% 100%;
    --popover-foreground: 240 10% 3.9%;
    --primary: 240 5.9% 10%;
    --primary-foreground: 0 0% 98%;
    --secondary: 240 4.8% 95.9%;
    --secondary-foreground: 240 5.9% 10%;
    --muted: 240 4.8% 95.9%;
    --muted-foreground: 240 3.8% 46.1%;
    --accent: 240 4.8% 95.9%;
    --accent-foreground: 240 5.9% 10%;
    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 5.9% 90%;
    --input: 240 5.9% 90%;
    --ring: 240 10% 3.9%;
    --chart-1: 12 76% 61%;
    --chart-2: 173 58% 39%;
    --chart-3: 197 37% 24%;
    --chart-4: 43 74% 66%;
    --chart-5: 27 87% 67%;
    --radius: 0.5rem;
  }
  .dark {
    --background: 240 10% 3.9%;
    --foreground: 0 0% 98%;
    --card: 240 10% 3.9%;
    --card-foreground: 0 0% 98%;
    --popover: 240 10% 3.9%;
    --popover-foreground: 0 0% 98%;
    --primary: 0 0% 98%;
    --primary-foreground: 240 5.9% 10%;
    --secondary: 240 3.7% 15.9%;
    --secondary-foreground: 0 0% 98%;
    --muted: 240 3.7% 15.9%;
    --muted-foreground: 240 5% 64.9%;
    --accent: 240 3.7% 15.9%;
    --accent-foreground: 0 0% 98%;
    --destructive: 0 62.8% 30.6%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 3.7% 15.9%;
    --input: 240 3.7% 15.9%;
    --ring: 240 4.9% 83.9%;
    --chart-1: 220 70% 50%;
    --chart-2: 160 60% 45%;
    --chart-3: 30 80% 55%;
    --chart-4: 280 65% 60%;
    --chart-5: 340 75% 55%;
  }
}

例如,當我們配置背景色,就應該基于 tailwindcss 結合這里的自定義 css 變量使用。

<html className='bg-background'></html>

如果你還想要擴展顏色,則需要在同樣的位置新增配置。擴展起來還是比較方便。

!

注意需要同時修改 globals.css 與 tailwind.config.ts

五、總結

和 antd 相比,shadcn/ui 的場景與需求覆蓋還略顯不足。antd 能夠滿足更加復雜多樣的需求。因此,在做選擇上,一定要根據自己的實際情況慎重考慮。

shadcn/ui 的使用成本主要體現在,需要在使用之前,對 tailwindcss 有足夠的了解。在使用過程中,需要經常跟相關的配置文件打交道。

shadcn/ui 的優勢在于,足夠的靈活。我們可以比較輕松的植入自己想要的樣式,也能夠直接修改組件源碼,擴展組件的基礎能力,他在定制與擴展上面,做到了一個比較好的平衡取舍,這也是他能火起來的主要原因之一。因此理論上來說,如果我們的技術能力足夠,我們可以直接覆蓋所有的復雜場景。但是這也要求開發者具備更強的開發能力。

shadcn/ui 也更容易擴展和集成其他的三方工具庫來充實自己的能力。但是由于國外的項目,交互相對與國內的產品而言,還是比較簡單。因此,如果使用 shadcn/ui 來開發國內的項目,可能會遇到許多比較難受的點

最后根據群友反饋,許多 AI 大模型都是基于 shadcn/ui 來訓練直接生成頁面,因此,在 AI 的準確度上來說,shadcn/ui 具備很強的優勢。

責任編輯:姜華 來源: 這波能反殺
相關推薦

2021-09-13 08:38:42

阿里時間成本

2020-07-27 08:26:03

數據庫 SQL索引

2021-10-11 10:41:14

TCP傳輸層協議網絡

2020-04-14 10:06:20

微服務Netflix語言

2025-03-24 08:00:00

數據庫開發代碼

2025-02-28 06:22:26

2023-03-27 09:50:16

RocketMQ中間件

2024-05-14 08:20:59

線程CPU場景

2021-10-29 12:01:11

HTTP代碼前端

2022-08-12 10:02:24

數據中心谷歌

2022-10-25 17:53:09

Java線程池

2022-12-12 17:11:32

P6SpySQL

2024-01-04 14:16:05

騰訊紅黑樹Socket

2021-12-03 11:57:27

代碼##語言

2025-04-15 19:52:04

2020-04-30 11:25:32

Insert into數據庫索引

2019-09-27 09:13:55

Redis內存機制

2021-04-29 23:45:07

函數式接口可用性

2021-10-08 08:09:13

Facebook算法DNS

2025-07-28 02:55:00

虛擬列表JavaScript單線程
點贊
收藏

51CTO技術棧公眾號

六月婷婷中文字幕| 国产乱国产乱老熟300| 浪潮色综合久久天堂 | 国产精品自拍网| 神马久久久久久久久久久| 国产午夜精品一区在线观看| 亚洲国产精品久久一线不卡| 日韩av影视| 在线免费a视频| 亚洲成色精品| 上原亚衣av一区二区三区| 好吊操视频这里只有精品| 周于希免费高清在线观看| ...av二区三区久久精品| 国内一区在线| 97超碰中文字幕| 久久高清一区| 欧美精品免费在线观看| 谁有免费的黄色网址| 一区二区三区四区精品视频| 欧美怡红院视频| av日韩一区二区三区| 97电影在线观看| av一本久道久久综合久久鬼色| 国产精品美女999| 国产在线视频99| 亚洲国产一区二区在线观看| 在线精品播放av| 国产黄色三级网站| 日韩精品一区国产| 欧美日本在线播放| 久久九九国产视频| 女人高潮被爽到呻吟在线观看| 亚洲色图.com| 亚洲欧美日韩国产成人综合一二三区| 你懂的在线看| eeuss影院一区二区三区 | 国产喷水福利在线视频| 日韩精品免费视频人成| 91爱视频在线| 91蜜桃视频在线观看| 牛夜精品久久久久久久99黑人| 色综合亚洲精品激情狠狠| 国产精品久久久久无码av色戒| 国偷自产av一区二区三区| 精品日韩在线一区| 激情小说欧美色图| 一本一道久久a久久| 欧美成人一区二区| 性生活在线视频| 欧美三级一区| 日韩视频免费直播| 免费人成视频在线播放| 成人av婷婷| 精品成人免费观看| av在线播放网址| 欧美自拍视频| 亚洲欧美中文日韩在线| 午夜在线观看一区| 日韩欧美网站| 久久精品国产欧美亚洲人人爽| 婷婷国产成人精品视频| 国产精品88久久久久久| 久久av中文字幕| 精品97人妻无码中文永久在线| 午夜久久一区| 韩国一区二区电影| 青青青国产在线| 日韩在线一二三区| 国产在线观看精品| 精品国产999久久久免费| 国产成人av一区二区三区在线观看| 99精品国产高清一区二区| 亚洲黄色在线播放| 91免费国产视频网站| 日韩欧美亚洲v片| 欧美69xxx| 亚洲一区影音先锋| 欧美视频第三页| 欧美美女被草| 精品久久免费看| 亚洲午夜福利在线观看| 日韩欧美1区| 欧美日韩爱爱视频| 人人草在线观看| 紧缚奴在线一区二区三区| 91香蕉视频在线下载| 四虎影视精品成人| 中文字幕不卡在线观看| 亚洲啊啊啊啊啊| 中文字幕乱码在线播放| 欧美另类z0zxhd电影| 美女久久久久久久久| 精品精品久久| 久久全国免费视频| 亚洲一级片免费看| av电影在线观看一区| 亚洲精品中文字幕在线| 黑人玩欧美人三根一起进| 在线精品亚洲一区二区不卡| 欧美69精品久久久久久不卡| 一呦二呦三呦国产精品| 久久天天躁狠狠躁夜夜爽蜜月| 日韩精品国产一区二区| 久久精品国产99国产精品| 精品欧美一区二区久久久伦| 欧美精品日韩少妇| 欧美午夜美女看片| 日韩乱码在线视频| 日韩视频专区| 变态调教一区二区三区| 色老汉一区二区三区| 色综合久久久无码中文字幕波多| 国产欧美日韩一区二区三区四区| 欧美日产国产成人免费图片| 一本到在线视频| 久久久亚洲高清| 青青草国产免费| 国产成人免费av一区二区午夜| 亚洲免费电影一区| 久久久久久久蜜桃| 久久99国产精品麻豆| 欧美日韩电影一区二区| 色婷婷视频在线观看| 欧美性生交片4| 日韩人妻无码一区二区三区| 欧美午夜视频| 亚洲一区二区久久久久久久 | 中文字幕精品久久| 成年人免费高清视频| 国产高清一区日本| 欧美h视频在线观看| 欧美成人app| 亚洲视频自拍偷拍| 免费看一级视频| ww亚洲ww在线观看国产| 国产精品国产亚洲精品看不卡| 欧美精品影院| 欧美另类高清videos| 亚洲天堂中文在线| 国产精品私人自拍| 色七七在线观看| 成人网18免费网站| 国产精品美女主播| 尤物视频在线免费观看| 欧美性生活久久| 正在播放国产对白害羞| 美女视频黄 久久| 亚洲国产成人不卡| 欧美高清你懂的| 最近2019中文字幕mv免费看| 波多野结衣绝顶大高潮| 国产视频在线观看一区二区三区| aⅴ在线免费观看| 欧美极品在线观看| 国产精品久久久久福利| 91官网在线| 欧美巨大另类极品videosbest| av黄色免费在线观看| 国产一区二区三区美女| 久久人妻无码一区二区| 岛国成人av| 欧美专区第一页| 国产中文在线观看| 欧美老肥妇做.爰bbww| 卡通动漫亚洲综合| 成人动漫av在线| 漂亮人妻被中出中文字幕| 国产亚洲欧美日韩在线观看一区二区 | 国产亚洲精品免费| 国产一区视频免费观看| 俺要去色综合狠狠| 91免费版网站入口| aa视频在线观看| 亚洲石原莉奈一区二区在线观看| 中文字幕乱码人妻无码久久| 亚洲欧美综合另类在线卡通| 亚欧美一区二区三区| 亚洲区第一页| 日韩欧美视频一区二区三区四区| 国产一区二区三区亚洲综合| 国模视频一区二区| yourporn在线观看视频| 日韩一二三区不卡| 欧美日韩乱国产| 国产精品不卡视频| 第四色在线视频| 美女久久久精品| www.激情网| 欧美日韩国产在线观看网站 | 亚洲精品国产精品国| 欧美色视频日本高清在线观看| 欧美福利第一页| 国产老女人精品毛片久久| 日本韩国欧美在线观看| 91视频综合| 免费电影一区| 色妞ww精品视频7777| 国产精品va在线| 欧美性video| 伊人亚洲福利一区二区三区| 亚洲精品字幕在线| 欧美日韩一级片网站| 久久露脸国语精品国产91| 中文av一区二区| 91黄色免费视频| 国产一区不卡在线| 亚洲黄色a v| 99热这里只有精品8| 国产成年人在线观看| 精品久久久久久久久久久aⅴ| 国产v亚洲v天堂无码| 亚洲人体在线| 日本中文字幕久久看| 999av小视频在线| 久久亚洲春色中文字幕| 第三区美女视频在线| 亚洲第一页中文字幕| 国产免费一区二区三区最新不卡 | 国产精品成人免费电影| 爱情岛论坛亚洲品质自拍视频网站 | 国产美女精品视频| 桃色一区二区| 668精品在线视频| 丁香花在线电影| 欧美成人免费视频| 日本最黄一级片免费在线| 亚洲美女av电影| 午夜激情小视频| 亚洲成色www8888| 亚洲老妇色熟女老太| 欧美一级在线视频| 99热精品在线播放| 欧美丰满高潮xxxx喷水动漫| 中文字幕在线视频免费| 欧美在线观看一区| 中文字幕免费高清网站| 色综合久久天天综合网| 美日韩一二三区| 精品福利一区二区| av大片免费观看| 偷偷要91色婷婷| 日本高清www免费视频| 午夜婷婷国产麻豆精品| 欧美成人精品欧美一级乱黄| 天天色综合天天| 婷婷激情五月网| 欧美性猛交xxxx乱大交3| 国产三级av片| 91国产福利在线| 欧美男人天堂网| 欧美三级视频在线播放| 中文字幕第一页在线播放| 欧美在线不卡一区| 亚洲最新av网站| 欧美一区三区四区| 亚洲va久久久噜噜噜无码久久| 欧美一级淫片007| 亚洲黄色小说网址| 日韩黄色在线免费观看| 久草视频在线看| 伊人久久免费视频| 欧洲美女少妇精品| 欧美区二区三区| 1234区中文字幕在线观看| 97视频免费在线看| 丝袜美腿一区| 91精品久久久久久久久| 精品视频91| 韩国成人一区| 欧洲杯半决赛直播| 激情图片qvod| 99热免费精品在线观看| 日韩av片网站| 国产1区2区3区精品美女| 99久久人妻精品免费二区| 国产欧美一区二区精品性色 | 成人免费视频| 美女少妇精品视频| 理论片午夜视频在线观看| 国产精品黄色av| 亚洲开心激情| 欧美高清视频一区| 91综合视频| 国产精品无码人妻一区二区在线| 日韩影院免费视频| 日批视频在线看| 久久尤物电影视频在线观看| 免费黄色国产视频| 午夜视频在线观看一区二区 | 成人在线爆射| 3d蒂法精品啪啪一区二区免费| 欧美人妖视频| 国产美女视频免费| 午夜亚洲伦理| 污污视频在线免费| 国产日产欧美一区| 日本熟女一区二区| 欧美美女一区二区三区| 无套内谢的新婚少妇国语播放| 色妞欧美日韩在线| 成人香蕉视频| 超碰在线观看97| 手机在线一区二区三区| 无码人妻丰满熟妇区96| 激情亚洲综合在线| 强伦人妻一区二区三区| 亚洲精品久久7777| 在线观看亚洲国产| 国产视频亚洲视频| 蜜桃成人365av| 亚洲japanese制服美女| 国产免费av一区二区三区| 青青青在线视频播放| 狠狠色丁香婷综合久久| 日韩精品无码一区二区三区久久久| 亚洲一区二区三区四区在线观看| 亚洲一卡二卡在线观看| 亚洲日本中文字幕| 男人天堂视频在线观看| 大波视频国产精品久久| 66视频精品| 第四色婷婷基地| 国产日韩欧美综合在线| 国产网址在线观看| 欧美高清hd18日本| 99青草视频在线播放视| 国产91网红主播在线观看| 国产欧美自拍一区| 成人区一区二区| 国产一区二区久久| 欧美a级片免费看| 欧美日本国产视频| avtt亚洲| 国产欧美一区二区三区久久人妖| 精品国产一区二区三区噜噜噜 | 日本一区二区综合亚洲| 国产专区第一页| 亚洲精品福利视频| 国产一二在线播放| 久久国产精品久久| 夜夜夜久久久| 蜜臀av一区二区三区有限公司| 亚洲成人动漫精品| 欧美一区二区三区激情| 欧美韩日一区二区| 97视频一区| 日韩精品免费一区| 丰满白嫩尤物一区二区| 日韩激情一区二区三区| 亚洲国产精品久久久久| 婷婷电影在线观看| 欧美一区二区三区在线播放| 丝袜a∨在线一区二区三区不卡| 一区二区黄色片| 欧美无人高清视频在线观看| av免费在线一区二区三区| 国产精品视频久久| 羞羞色午夜精品一区二区三区| 在线观看av免费观看| 一区二区三区蜜桃| 男人天堂手机在线观看| 91爱视频在线| 成人3d动漫在线观看| 亚洲午夜激情影院| 亚洲宅男天堂在线观看无病毒| 丰满人妻av一区二区三区| 97色在线播放视频| 日本精品三区| 91亚洲一区二区| 天天操天天干天天综合网| 美国成人毛片| 91在线观看免费高清完整版在线观看| 欧美va天堂在线| 日韩无码精品一区二区| 色婷婷综合久久久中文一区二区| 粉嫩av在线播放| 成人片在线免费看| 久久国产日韩| 永久免费看mv网站入口| 亚洲变态欧美另类捆绑| 午夜日韩成人影院| 色爽爽爽爽爽爽爽爽| 波多野结衣视频一区| 亚洲精品一区二区二区| 久久成人在线视频| 婷婷精品视频| 天天影视色综合| 福利视频第一区| 大地资源网3页在线观看| 精品毛片久久久久久| 另类小说欧美激情| 日韩欧美一区二区一幕| 爽爽爽爽爽爽爽成人免费观看| 99精品国产一区二区三区2021| 性欧美极品xxxx欧美一区二区| 一区二区激情小说| yw在线观看| 久久国产一区| 国产一区二区女|