html设置图片左右轮播js,js实现左右切换轮播图思路

我们在 CSS 阶段就已经接触到轮播图。通过轮播图我们可以达到一些好玩的特效,但使用 CSS 做出来的轮播图只有左右切换,渐变切换和简单的点击切换。局限性较大,观看效果也不佳。但当我们接触 js 之后,你就发现使用js来实现轮播图后,在看CSS实现轮播的效果就是...。我想说啥你知道的。废话不多说,咱们一起看看如何使用js来实现轮播效果。

(本文以阴阳师中“平安世界”模块的轮播图为例)

这个轮播图,我们通过两大模块构成;左右点击模块和姓名点击模块。然后在两者相关联来达到最终的效果。

在使用js实现轮播图的效果前,先使用HTML和CSS完善这一模块的布局。

本轮播图使用8张图片。每次出现两张。我们在使用HTML和CSS布局时可以先把第一组的两张图片放好位置。其他的放在两边隐藏起来。需要使用的时候在出现移动到中间。

左右点击切换模块:

我们通过对左右按钮进行点击监听。在点击后做出反应。左右点击的思路一样。我们先说一下右边按钮点击事件。

当我们点击右边按钮后,我们通过对点击次数进行累计。此处我使用初始化常量然后累加最后通过判断来达到循环效果

对每一张图片进行编码,以此来达到循环切换图片的效果。在切换图片时,我们可以使用排他思想。当点击按钮切换下一张图片的时候,我们可以先遍历所有的图片,把所有的图片移动到两边,然后将要移动的图片移动到中央来达到切换效果

在移动的过程中的动画和定时器设置的延迟可以自己添加一下。

左边按钮的原理和右边一样反操作即可。注意常量要使用一个。否则两个按钮都只能单方向运动,可能还会出现其他问题。

本次现讲一下左右切换的思路。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个Vue项目多模块集成主题切换的demo,使用了Sass作为CSS预处理器和Element UI作为UI库: 1. 安装Element UI和Sass ``` npm install element-ui sass sass-loader ``` 2. 创建一个theme.scss文件,定义变量和样式 ```scss // 定义主题变量 $primary-color: #409EFF; $success-color: #67C23A; $warning-color: #E6A23C; $error-color: #F56C6C; $info-color: #909399; // 根据变量定义样式 .el-button { background-color: $primary-color; border-color: $primary-color; &:hover, &:focus { background-color: lighten($primary-color, 10%); border-color: lighten($primary-color, 10%); } } .el-alert { background-color: $info-color; border-color: $info-color; } ``` 3. 在main.js文件中添加以下代码,引入Element UI和theme.scss文件 ```js import Vue from 'vue'; import ElementUI from 'element-ui'; import 'element-ui/lib/theme-chalk/index.css'; import './theme.scss'; Vue.use(ElementUI); ``` 4. 创建一个ThemeSwitcher组件,用来切换主题 ```html <template> <div> <el-radio-group v-model="theme" @change="changeTheme"> <el-radio-button label="theme-light">浅色主题</el-radio-button> <el-radio-button label="theme-dark">深色主题</el-radio-button> </el-radio-group> </div> </template> <script> export default { data() { return { theme: 'theme-light' } }, methods: { changeTheme() { const oldLink = document.getElementById('theme'); const newLink = document.createElement('link'); newLink.id = 'theme'; newLink.rel = 'stylesheet'; newLink.href = `/themes/${this.theme}.css`; document.head.replaceChild(newLink, oldLink); } } } </script> ``` 5. 创建两个主题样式文件,分别为theme-light.css和theme-dark.css,放在public/themes文件夹下 6. 在App.vue中引入ThemeSwitcher组件,并在页面中使用 ```html <template> <div id="app"> <theme-switcher></theme-switcher> <router-view></router-view> </div> </template> <script> import ThemeSwitcher from './components/ThemeSwitcher.vue'; export default { components: { ThemeSwitcher } } </script> ``` 这样就可以实现多模块集成主题切换了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值