vue3鼠标经过显示按钮

简介: 在前端开发中,我们经常需要在页面中添加一些交互效果来提升用户体验。其中一个常见的需求就是鼠标经过某个元素时显示一个按钮,这个按钮可以用于触发一些操作或者显示更多的内容。

在前端开发中,我们经常需要在页面中添加一些交互效果来提升用户体验。其中一个常见的需求就是鼠标经过某个元素时显示一个按钮,这个按钮可以用于触发一些操作或者显示更多的内容。


在本篇文章中,我将会介绍如何使用 Vue3 实现一个鼠标经过显示按钮的效果,同时还会涉及一些 Vue3 的基本用法和特性。让我们开始吧!


创建 Vue3 项目

首先,我们需要创建一个 Vue3 项目。可以使用 Vue CLI 来快速创建一个 Vue3 项目,具体步骤如下:


安装 Vue CLI:


npm install -g @vue/cli

创建一个新的 Vue3 项目:


vue create vue-mouseover-button

选择默认的配置选项,等待项目创建完成。


添加鼠标经过显示按钮的功能

接下来,我们需要在 Vue3 项目中添加鼠标经过显示按钮的功能。具体步骤如下:


在 src/components 目录下创建一个新的组件文件 MouseoverButton.vue,并添加以下代码:


<template>
  <div class="mouseover-button" @mouseover="showButton" @mouseleave="hideButton">
    <div class="content">
      <slot></slot>
    </div>
    <button class="button" v-show="show">Click me!</button>
  </div>
</template>
<script>
import { ref } from 'vue'
export default {
  setup(props, { emit }) {
    const show = ref(false)
    const showButton = () => {
      show.value = true
    }
    const hideButton = () => {
      show.value = false
    }
    return {
      show,
      showButton,
      hideButton
    }
  }
}
</script>
<style scoped>
.mouseover-button {
  position: relative;
  display: inline-block;
}
.content {
  display: inline-block;
}
.button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 10px 20px;
  background-color: #42b983;
  color: #fff;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}
</style>


在这个组件中,我们使用了 @mouseover 和 @mouseleave 事件来监听鼠标的移入和移出事件。当鼠标移入时,我们将 show 的值设为 true,从而显示按钮;当鼠标移出时,我们将 show 的值设为 false,从而隐藏按钮。


注意,我们在 setup 函数中使用了 Vue3 的新特性——Composition API。通过 ref 函数来创建响应式的数据,这样当 show 的值改变时,组件会自动更新视图。


在 App.vue 文件中使用 MouseoverButton 组件,并添加一些内容:


<template>
  <div class="app">
    <MouseoverButton>
      <h1>Hello, Vue3!</h1>
      <p>Move your mouse over me to see the button.</p>
    </MouseoverButton>
  </div>
</template>
<script>
import MouseoverButton from './components/MouseoverButton.vue'
export default {
  name: 'App',
  components: {
    MouseoverButton
  }
}
</script>
<style>
.app {
  text-align: center;
  margin-top: 100px;
}
</style>


在这个组件中,我们使用了 MouseoverButton 组件,并在其中添加了一些内容。当鼠标移入这个组件时,会显示一个按钮,用户可以点击这个按钮来触发一些操作。


注意,我们在这里使用了 import 和 export 语法来导入和导出组件。这是 ES6 中的语法,Vue3 默认使用的是 ES6 模块化。另外,我们使用了 name 属性来给组件命名。


运行项目

现在,我们已经完成了鼠标经过显示按钮的功能,可以运行项目来查看效果了。在终端中执行以下命令:


npm run serve

然后在浏览器中访问

http://localhost:8080,就可以看到我们创建的

http://localhost:8080/

Vue3 应用了。当鼠标移入页面中的 MouseoverButton 组件时,会显示一个按钮,用户可以点击这个按钮来触发一些操作。


总结

本篇文章介绍了如何使用 Vue3 实现一个鼠标经过显示按钮的效果。我们使用了 Vue3 的 Composition API 来创建响应式的数据,并使用了 @mouseover 和 @mouseleave 事件来监听鼠标的移入和移出事件。通过这个例子,我们可以了解到 Vue3 的一些基本用法和特性。希望这篇文章能对你有所帮助!


相关文章
|
5天前
|
前端开发 JavaScript API
基于Vue3+Hooks实现4位随机数和60秒倒计时
本文介绍了如何在Vue3中使用Hooks API来实现生成4位随机数和执行60秒倒计时的功能,并提供了详细的代码示例和运行效果展示。
23 1
基于Vue3+Hooks实现4位随机数和60秒倒计时
|
1天前
|
JSON JavaScript 前端开发
Vue3在工作中使用的一些经验总结
这篇文章是关于Vue 3项目中使用TypeScript的一些经验总结,包括如何配置TSLint进行代码规范和类型检查,以及如何将现有的JavaScript代码迁移到TypeScript的步骤和注意事项。
Vue3在工作中使用的一些经验总结
|
4天前
|
JavaScript 算法 API
Vue 3有哪些新特性
【8月更文挑战第16天】Vue 3有哪些新特性
25 1
|
4天前
|
JavaScript
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
这篇文章介绍了在Vue中如何使用Swiper插件创建轮播图,解决Swiper左右切换按钮不生效的问题,并展示了如何将Swiper轮播图抽离成一个可复用的公共组件,同时提供了详细的安装、配置和优化建议。
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
|
5天前
|
JavaScript
使用Vue实现一个当鼠标悬浮时出现,鼠标离开时消失的双层菜单
这篇文章介绍了如何在Vue中实现一个鼠标悬浮时出现、鼠标离开时消失的双层菜单,并提供了详细的代码示例和运行效果展示。
26 0
使用Vue实现一个当鼠标悬浮时出现,鼠标离开时消失的双层菜单
|
5天前
|
JavaScript UED
如何在Vue3项目中使用防抖节流技巧
在Vue 3项目中使用防抖和节流技巧以优化组件性能,包括使用`lodash`库和自定义实现这两种方法。
10 0
如何在Vue3项目中使用防抖节流技巧
|
1天前
|
JavaScript 前端开发 API
Vue3入门
Vue3入门
4 0
|
4天前
|
JavaScript
创建 Vue3 项目
创建 Vue3 项目
11 0
|
1天前
|
JavaScript
Vue学习之--------路由的query、params参数、路由命名(3)(2022/9/5)
这篇文章详细介绍了Vue路由中的query参数、命名路由、params参数以及props配置的使用方式,并通过实际项目案例展示了它们在开发中的应用和测试结果,同时解释了`<router-link>`的`replace`属性如何影响浏览器历史记录。
Vue学习之--------路由的query、params参数、路由命名(3)(2022/9/5)
|
1天前
|
JavaScript
Vue学习之--------VueX(2022/8/31)
这篇文章是关于VueX的基础知识介绍,涵盖了VueX中的state、mutations、getters和actions的定义和使用,以及Action提交mutation而非直接变更状态,以及mutations的同步执行特性。
Vue学习之--------VueX(2022/8/31)