Vue3 + Tailwind CSS 菜单搜索组件
通过以上步骤,你创建了一个带有搜索功能的菜单组件。用户可以在输入框中输入文本,列表将动态显示匹配的菜单项。这个组件使用了Vue 3的组合式API和Tailwind CSS来提供样式和交互功能。
一、技术栈
- Vue 3: 使用 Composition API 进行逻辑组织,利用其响应式系统。
- Tailwind CSS: 用于快速构建美观的 UI 界面,提供原子化的 CSS 类。
- Vue Router: 用于菜单项点击后的路由导航。
二、核心功能
- 实时搜索: 用户输入关键词时,实时从菜单数据中筛选匹配项。
- 扁平化处理: 将层级嵌套的菜单数据扁平化,并生成面包屑路径,方便搜索和展示。
- 弹窗展示: 点击搜索框或使用快捷键
Ctrl+K
时,以模态弹窗形式展示搜索界面和结果。 - 键盘导航: 支持使用
↑
、↓
键在搜索结果中选择,Enter
键确认导航,Esc
键关闭弹窗。 - 模糊匹配: 同时搜索菜单标题和面包屑路径。
- 清晰提示: 搜索无结果时给出提示,并在弹窗底部显示操作快捷键。
- 自动聚焦: 弹窗打开时,搜索框自动获得焦点。
三、菜单数据结构 (menus.js
)
组件依赖一个特定结构的菜单数据。menus.js
文件导出了一个名为 menus
的数组,每个菜单项对象包含以下属性:
title
(String): 菜单项的显示标题。icon
(String, 可选): 菜单项的图标标识 (具体渲染方式需自行实现或对接图标库)。path
(String, 可选): 菜单项对应的路由路径。只有包含path
的菜单项才会被视为可导航的最终菜单。children
(Array, 可选): 子菜单项数组,结构与父级相同,用于表示层级关系。
在Vue 3和Tailwind CSS中创建一个菜单搜索组件,你可以遵循以下步骤。这个组件将包括一个输入框用于搜索,以及一个列表来显示匹配的菜单项。我们将使用Vue 3的组合式API(Composition API)来构建这个组件。
my.tv.sohu.com/us/336831077/671274983.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3NDk4My5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671275052.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3NTA1Mi5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671274847.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3NDg0Ny5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671274871.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3NDg3MS5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671274937.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI3NDkzNy5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671274665.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjc0NjY1LnNodG1s.html
my.tv.sohu.com/us/367139555/671275012.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3NTAxMi5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671274948.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3NDk0OC5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671274636.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3NDYzNi5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671274578.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3NDU3OC5zaHRtbA==.html
my.tv.sohu.com/us/328355069/671274710.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3NDcxMC5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671274473.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3NDQ3My5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671274538.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3NDUzOC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671274102.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3NDEwMi5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671273963.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3Mzk2My5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671274281.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI3NDI4MS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671274152.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3NDE1Mi5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671274140.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjc0MTQwLnNodG1s.html
my.tv.sohu.com/us/250570713/671274704.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3NDcwNC5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671274086.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3NDA4Ni5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671274328.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3NDMyOC5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671274034.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3NDAzNC5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671274026.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3NDAyNi5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671274218.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3NDIxOC5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671274213.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI3NDIxMy5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671273634.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MzYzNC5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671273977.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3Mzk3Ny5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671273785.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjczNzg1LnNodG1s.html
my.tv.sohu.com/us/310386057/671273869.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3Mzg2OS5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671273571.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3MzU3MS5zaHRtbA==.html
my.tv.sohu.com/us/328355069/671273813.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MzgxMy5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671273330.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MzMzMC5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671273499.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjczNDk5LnNodG1s.html
my.tv.sohu.com/us/310386057/671273627.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MzYyNy5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671273636.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3MzYzNi5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671273429.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MzQyOS5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671273442.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjczNDQyLnNodG1s.html
my.tv.sohu.com/us/439598133/671273613.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MzYxMy5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671273131.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3MzEzMS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671273198.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MzE5OC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671273167.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MzE2Ny5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671272787.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3Mjc4Ny5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671273288.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjczMjg4LnNodG1s.html
my.tv.sohu.com/us/328355069/671273234.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MzIzNC5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671272888.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3Mjg4OC5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671273015.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3MzAxNS5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671272682.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MjY4Mi5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671272162.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3MjE2Mi5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671272096.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI3MjA5Ni5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671272882.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3Mjg4Mi5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671272791.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3Mjc5MS5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671272157.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MjE1Ny5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671272761.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjcyNzYxLnNodG1s.html
my.tv.sohu.com/us/328355069/671272597.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MjU5Ny5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671272763.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3Mjc2My5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671272653.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MjY1My5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671272179.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MjE3OS5zaHRtbA==.html
my.tv.sohu.com/us/328355069/671272622.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MjYyMi5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671272577.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MjU3Ny5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671272396.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MjM5Ni5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671272444.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MjQ0NC5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671272373.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MjM3My5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671272457.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3MjQ1Ny5zaHRtbA==.html
my.tv.sohu.com/us/328355069/671272324.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MjMyNC5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671272327.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MjMyNy5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671271986.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjcxOTg2LnNodG1s.html
my.tv.sohu.com/us/439597800/671272308.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3MjMwOC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671271899.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MTg5OS5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671271944.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3MTk0NC5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671272304.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MjMwNC5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671271892.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MTg5Mi5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671271924.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MTkyNC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671271665.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MTY2NS5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671271805.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MTgwNS5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671271586.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MTU4Ni5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671271828.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3MTgyOC5zaHRtbA==.html
my.tv.sohu.com/us/328355069/671271808.shtml
tv.sohu.com/v/dXMvMzI4MzU1MDY5LzY3MTI3MTgwOC5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671271227.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3MTIyNy5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671271739.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MTczOS5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671271540.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3MTU0MC5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671271486.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MTQ4Ni5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671271333.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI3MTMzMy5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671271570.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjcxNTcwLnNodG1s.html
my.tv.sohu.com/us/439598132/671271661.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MTY2MS5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671271641.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MTY0MS5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671271633.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MTYzMy5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671271175.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MTE3NS5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671271236.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI3MTIzNi5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671271535.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MTUzNS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671271367.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MTM2Ny5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671271229.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MTIyOS5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671271523.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MTUyMy5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671271164.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3MTE2NC5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671271072.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjcxMDcyLnNodG1s.html
my.tv.sohu.com/us/310386057/671271332.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MTMzMi5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671271285.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3MTI4NS5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671271082.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MTA4Mi5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671271244.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3MTI0NC5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671271071.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MTA3MS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671271249.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MTI0OS5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671270775.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MDc3NS5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671270866.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MDg2Ni5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671270735.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MDczNS5zaHRtbA==.html
my.tv.sohu.com/us/357366448/671270651.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI3MDY1MS5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671269598.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI2OTU5OC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671270295.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI3MDI5NS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671270531.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI3MDUzMS5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671269980.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI2OTk4MC5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671270597.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI3MDU5Ny5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671270485.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3MDQ4NS5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671270300.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MDMwMC5zaHRtbA==.html
my.tv.sohu.com/us/38510409/671269776.shtml
tv.sohu.com/v/dXMvMzg1MTA0MDkvNjcxMjY5Nzc2LnNodG1s.html
my.tv.sohu.com/us/357366448/671269770.shtml
tv.sohu.com/v/dXMvMzU3MzY2NDQ4LzY3MTI2OTc3MC5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671270331.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI3MDMzMS5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671270304.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI3MDMwNC5zaHRtbA==.html
my.tv.sohu.com/us/250570713/671269823.shtml
tv.sohu.com/v/dXMvMjUwNTcwNzEzLzY3MTI2OTgyMy5zaHRtbA==.html
my.tv.sohu.com/us/439598702/671269698.shtml
tv.sohu.com/v/dXMvNDM5NTk4NzAyLzY3MTI2OTY5OC5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671270087.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MDA4Ny5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671270083.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI3MDA4My5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671269869.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI2OTg2OS5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671269954.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI2OTk1NC5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671270155.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3MDE1NS5zaHRtbA==.html
my.tv.sohu.com/us/301011164/671269916.shtml
tv.sohu.com/v/dXMvMzAxMDExMTY0LzY3MTI2OTkxNi5zaHRtbA==.html
my.tv.sohu.com/us/303430571/671269743.shtml
tv.sohu.com/v/dXMvMzAzNDMwNTcxLzY3MTI2OTc0My5zaHRtbA==.html
my.tv.sohu.com/us/310386057/671270017.shtml
tv.sohu.com/v/dXMvMzEwMzg2MDU3LzY3MTI3MDAxNy5zaHRtbA==.html
my.tv.sohu.com/us/439598133/671270008.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMzLzY3MTI3MDAwOC5zaHRtbA==.html
my.tv.sohu.com/us/308331651/671269769.shtml
tv.sohu.com/v/dXMvMzA4MzMxNjUxLzY3MTI2OTc2OS5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671270025.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI3MDAyNS5zaHRtbA==.html
my.tv.sohu.com/us/439597800/671269810.shtml
tv.sohu.com/v/dXMvNDM5NTk3ODAwLzY3MTI2OTgxMC5zaHRtbA==.html
my.tv.sohu.com/us/439598132/671269600.shtml
tv.sohu.com/v/dXMvNDM5NTk4MTMyLzY3MTI2OTYwMC5zaHRtbA==.html
my.tv.sohu.com/us/367139555/671269746.shtml
tv.sohu.com/v/dXMvMzY3MTM5NTU1LzY3MTI2OTc0Ni5zaHRtbA==.html
my.tv.sohu.com/us/336831077/671269802.shtml
tv.sohu.com/v/dXMvMzM2ODMxMDc3LzY3MTI2OTgwMi5zaHRtbA==.html
my.tv.sohu.com/us/232677506/671269500.shtml
tv.sohu.com/v/dXMvMjMyNjc3NTA2LzY3MTI2OTUwMC5zaHRtbA==.html
步骤 1: 安装Vue 3和Tailwind CSS
确保你的项目中已经安装了Vue 3和Tailwind CSS。如果还没有安装,你可以通过以下命令来安装:
bashCopy Code
npm install vue@next npm install tailwindcss@latest postcss@latest autoprefixer@latest
步骤 2: 配置Tailwind CSS
在你的Vue项目中,创建一个Tailwind CSS的配置文件tailwind.config.js
(如果尚未创建):
javascriptCopy Code
module.exports = { content: ["./index.html", "./src/**/*.{vue,js,ts,jsx,tsx}"], theme: { extend: {}, }, plugins: [], }
确保在你的postcss.config.js
中添加Tailwind CSS:
javascriptCopy Code
module.exports = { plugins: { tailwindcss: {}, autoprefixer: {}, }, }
步骤 3: 添加Tailwind CSS到你的Vue组件中
在你的Vue组件中(例如MenuSearch.vue
),添加Tailwind CSS的样式。你可以在<style>
标签中使用Tailwind类:
vueCopy Code
<template> <div class="max-w-md mx-auto mt-8"> <input type="text" class="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:border-blue-500" placeholder="Search..." v-model="searchQuery" /> <ul class="mt-4"> <li v-for="item in filteredItems" :key="item.id" class="py-2 border-b border-gray-200"> {{ item.name }} </li> </ul> </div> </template> <script setup> import { ref, computed } from 'vue'; const searchQuery = ref(''); const items = ref([ { id: 1, name: 'Item 1' }, { id: 2, name: 'Item 2' }, { id: 3, name: 'Item 3' }, // 更多项目... ]); const filteredItems = computed(() => { return items.value.filter(item => item.name.toLowerCase().includes(searchQuery.value.toLowerCase())); }); </script>
步骤 4: 使用组件
在你的Vue应用的其他部分(例如App.vue
),你可以这样使用MenuSearch
组件:
vueCopy Code
<template> <div id="app"> <MenuSearch /> </div> </template> <script> import MenuSearch from './components/MenuSearch.vue'; export default { name: 'App', components: { MenuSearch, }, }; </script>
总结:
通过以上步骤,你创建了一个带有搜索功能的菜单组件。用户可以在输入框中输入文本,列表将动态显示匹配的菜单项。这个组件使用了Vue 3的组合式API和Tailwind CSS来提供样式和交互功能
更多推荐
所有评论(0)