当前位置: 首页 > news >正文

嘉兴seo站长工具seo排名查询

嘉兴seo,站长工具seo排名查询,郑州前端开发培训机构,动漫设计与制作怎么样可能你疑惑为啥名字和功能不一样,哈哈哈,不要怀疑,这只是我打错名字懒得改了。。。 📅 我们继续 50 个小项目挑战!—— RandomChoicePicker组件 仓库地址:https://github.com/SunACong/50-vue-projects 项…

可能你疑惑为啥名字和功能不一样,哈哈哈,不要怀疑,这只是我打错名字懒得改了。。。

📅 我们继续 50 个小项目挑战!—— RandomChoicePicker组件

仓库地址:https://github.com/SunACong/50-vue-projects

项目预览地址:https://50-vue-projects.vercel.app/

在这里插入图片描述


使用 Vue 3 的 Composition API 和 <script setup> 语法结合 TailwindCSS 构建一个简单的标签输入组件。用户可以在文本框中输入多个选项,并通过逗号分隔,组件会自动将其拆分成可视化的“标签”展示出来。

🎯 组件目标

  • 接收用户输入的一段文本。
  • 使用逗号 , 分割输入内容。
  • 动态渲染为一组“标签”(Tag)。
  • 使用 TailwindCSS 快速构建美观现代的 UI 界面。
  • 提供清晰的交互反馈。

⚙️ 技术实现点

技术点描述
Vue 3 Composition API (<script setup>)使用响应式变量管理组件状态
v-model 双向绑定绑定 textarea 输入值
watchEffect 副作用监听自动拆分并更新 tagList
v-for 渲染列表动态生成多个 Tag 元素
TailwindCSS 样式类快速构建现代 UI

🧱 组件实现

模板结构 <template>

<template><div class="flex h-screen items-center justify-center"><div class="rounded-2xl bg-gray-400 p-8"><h3 class="font-mono text-2xl">Enter all of the choices divided by a comma (',').<br />Press enter when you're done</h3><textareaclass="my-4 h-36 w-full bg-gray-200 p-4"placeholder="Enter choices here..."v-model="textareaText"></textarea><div class="flex gap-2" v-if="tagList[0] !== ''"><div class="h-8 rounded-2xl bg-amber-200 p-1" v-for="item in tagList" :key="item">{{ item }}</div></div></div></div>
</template>

脚本逻辑 <script setup>

<script setup>
import { ref, watchEffect } from 'vue'const textareaText = ref('')const tagList = ref([])const splitTag = () => {tagList.value = []const tagItems = textareaText.value.split(',')tagItems.forEach((item) => {tagList.value.push(item.trim()) // 去除前后空格})
}watchEffect(() => {splitTag()
})
</script>

🔍 重点效果实现

✅ 实时拆分与渲染

我们使用 v-model<textarea> 的值与 textareaText 进行双向绑定:

<textarea v-model="textareaText"></textarea>

并通过 watchEffect() 监听其变化,一旦发生变化就执行 splitTag() 方法,将输入内容以逗号分割为数组,并去除空格后推入 tagList

watchEffect(() => {splitTag()
})

💡 条件渲染优化

为了防止页面加载时显示空标签或错误信息,我们添加了一个判断条件:

<div class="flex gap-2" v-if="tagList[0] !== ''">

这样只有当用户输入了至少一个有效选项后,才会渲染出标签列表。


🎨 TailwindCSS 样式重点讲解

类名作用
flex, items-center, justify-center居中布局整个容器
h-screen容器高度为视口全高
rounded-2xl圆角大小为 1rem
bg-gray-400bg-gray-200bg-amber-200设置背景颜色
p-8, p-4, p-1不同层级的内边距
my-4上下外边距为 1rem
w-full宽度为 100%
h-36高度为 9rem
text-2xl字体大小为 1.5rem
font-mono使用等宽字体
gap-2flex 子元素之间间隔为 0.5rem
h-8高度为 2rem
rounded-2xl圆角为 1rem

这些 Tailwind 工具类帮助我们快速构建了一个简洁美观的输入界面和标签展示区域。


📁 常量定义 + 组件路由

constants/index.js 添加组件预览常量:

{id: 13,title: 'Random Choice Picker',image: 'https://50projects50days.com/img/projects-img/13-random-choice-picker.png',link: 'RandomChoicePicker',},

router/index.js 中添加路由选项:

{path: '/RandomChoicePicker',name: 'RandomChoicePicker',component: () => import('@/projects/RandomChoicePicker.vue'),},

🏁 总结

标签输入组件涵盖Vue 3 的响应式系统、副作用监听、动态渲染以及 TailwindCSS 的灵活样式组合。

  • 作为表单组件的一部分,用于收集用户输入的多项数据。

👉 下一篇,我们将完成AnimatedNavigation组件,一个非常有意思的动画的导航组件!🚀

http://www.fp688.cn/news/142477.html

相关文章:

  • 网站用户粘度搜狗权重查询
  • 系统开发的需求分析阶段的重要工作之一是哪些网站可以seo
  • 晚上网站推广软件免费版西地那非片的正确服用方法
  • 房地产集团网站建设方案中国教育培训网
  • 万泉河网站建设网站关键词快速排名软件
  • 网站菜单 网站导航优化措施最新回应
  • 网站死链怎么产生的好消息疫情要结束了
  • 深圳保障性住房可以买卖吗百度seo公司哪家强一点
  • 网站的推广代码是什么yandex引擎
  • 微网站模板多少钱网络营销推广技巧
  • 新开传奇最大网站999青岛关键词优化报价
  • 商务推广是什么意思百度seo灰色词排名代发
  • 自建淘宝客网站模板网站主页
  • 建筑网站新闻写那些好引流软件下载站
  • 邢台物流网站建设教育培训机构有哪些
  • 各大网站推广平台淘宝指数官网的网址
  • 石家庄网站建设蓝点电脑培训班多少费用
  • 张家港那家做网站百度一下进入首页
  • 绵阳的网站建设百度推广怎么推广
  • 深圳系统开发高端网站建设网络营销服务工具
  • 设计师接单的十个网站优化疫情防控措施
  • 做视频网站软件有哪些seo代做
  • 郑州市建设信息网站邵阳seo排名
  • 小程序商城开发稳定吗枣庄网络推广seo
  • 江苏网站建设找哪家微信营销方式
  • 珠海高端网站建设公司旺道智能seo系统
  • 免费创建论坛网站公司网站建设公司
  • 做抽奖的网站犯法吗谷歌官方网站首页
  • 自己写还是用wordpress网络优化工程师需要学什么
  • 网站不显示内容好口碑关键词优化地址