娴雅华服舞动间,Java实现后宫佳丽三千,引领世界独具魅力!

本文主要是介绍娴雅华服舞动间,Java实现后宫佳丽三千,引领世界独具魅力!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

前言

一、mounted是什么?

二、实现步骤

1.翻牌牌

实现APl:

效果图:

代码如下:

效果图:

2.进入后宫

完整代码:

效果图:

以下代码的解释:

总结


前言

上节课我们留了一个作业实现浏览器随机生成图片,这节课我们要学习更加有趣的课程,打造属于自己的后宫。大家羡不羡慕古代的皇帝,一夫多妻制,说不羡慕是不可能的。虽然现在法律不允许,但是我们可以自己在浏览器上打通二次元的壁垒,让二次元也能成为我们的后宫。喜欢二次元的不要错过我们这次的小课堂!下面有我来介绍后宫是如何搭建的:

一、mounted是什么?

在Vue中,mounted是一个生命周期钩子函数,用于在Vue实例挂载到DOM后执行一些操作。如果你想自动加载函数到mounted钩子中,你可以使用 mixin 或者 Vue插件。

1.使用mixin:

// 定义一个全局的mixin
Vue.mixin({
  mounted() {
    // 在每个组件的mounted钩子中执行的操作
    this.yourFunctionName();
  }
});

2.使用vue插件:

// 创建一个Vue插件
const YourPlugin = {
  install(Vue) {
    Vue.mixin({
      mounted() {
        // 在每个组件的mounted钩子中执行的操作
        this.yourFunctionName();
      }
    });
  }
};

// 在main.js中使用插件
Vue.use(YourPlugin);

这样,无论你在哪个组件中使用Vue实例,都会自动调用yourFunctionName函数在mounted钩子中。当然,你需要将yourFunctionName替换为你真正想要执行的函数名。

至于这里我为什么要提到mounted,因为如果我们想在新页面直接访问后台,得到所有的图片名称。用这个vue自动加载函数mounted方便我们直接获取图片,而不是通过点击事件箭头函数获取图片名称。

二、实现步骤

1.翻牌牌

实现最后的样式之前,我为了方便理解响应图片数据以及通过函数如何实现选妃的功能,特意设计一款类似翻牌牌的游戏。

实现APl:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><script src="/vue/vue.min.js"></script><script src="/vue/axios.min.js"></script><style>.image-container {width: 200px;height: 200px;perspective: 1000px;}.image-container img {width: 100%;height: 100%;backface-visibility: hidden;transition: transform 0.5s;}.image-container.flipped img {transform: rotateY(180deg);}.z1{width: 200px;height: 200px;background-color: pink;}.z2{width: 200px;height: 200px;background-color: red;}.z3{width: 200px;height: 200px;background-color: purple;}</style>
</head>
<body>
<div id="app"><div class="image-container" v-bind:class="{ flipped: isFlipped1 }" v-on:click="flipImage1"><img src="../photo/a.webp" v-if="!isFlipped1"><div class="z1" v-else></div></div><div class="image-container" v-bind:class="{ flipped: isFlipped2 }" v-on:click="flipImage2"><img src="../photo/b.webp" v-if="!isFlipped2"><div class="z2" v-else></div></div><div class="image-container" v-bind:class="{ flipped: isFlipped3 }" v-on:click="flipImage3"><img src="../photo/c.jpeg" v-if="!isFlipped3"><div class="z3" v-else></div></div>
</div>
</body>
<script>new Vue({el: '#app',data: {isFlipped1: true,isFlipped2: true,isFlipped3: true,},methods: {flipImage1: function() {this.isFlipped1 = !this.isFlipped1;},flipImage2: function() {this.isFlipped2 = !this.isFlipped2;},flipImage3: function() {this.isFlipped3 = !this.isFlipped3;}}});
</script>

这里也能看得出来图片都是路径确定,不利于大型项目的后台数据的响应,但是思路是通过点击让v-bind和v-if的属性来回切换,达到翻牌子的效果,我们也可以用这样的思路去优化代码,让代码更加完整。

效果图:

 是不是很有意思?现在我们把代码优化一下

代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>翻牌牌</title><script src="/vue/vue.min.js"></script><script src="/vue/axios.min.js"></script><style>.f{display: flex;justify-content: space-around;}.f>div{width: 300px;height: 350px;cursor: pointer;background-size: 300px 350px;margin-left: 30px;}.f>div:nth-child(odd){background-color: rebeccapurple;}.f>div:nth-child(even){background-color: pink;}@keyframes xz {0%{transform: rotateY(0deg);background-image: url("");}100%{transform: rotateY(180deg);}}@keyframes xzr {0%{transform: rotateY(180deg);}100%{transform: rotateY(0deg);background-image: url("");}}.xz{animation: xz 1s linear 1 forwards;}.xzr{animation: xzr 1s linear 1 forwards;}</style>
</head>
<body>
<div id="app"><button onClick="location.assign('/home.html')">进入后宫</button><div class="f"><div v-for="i in 6" @click="xzImg($event,i)"></div></div><hr><img src="/randomImgC" alt="1" width="400" height="450"><br><button οnclick="location.reload()">换一个</button>
</div>
</body>
<script>new Vue({el:'#app',data:{//记录每个图片被点击的次数arr:[0,0,0,0,0,0]},methods:{xzImg(e,i){if (this.arr[i-1]%2){//1e.target.style.backgroundImage='url()'e.target.className='xzr'}else {//0e.target.style.backgroundImage='url(/randomImgC?'+i+')'e.target.className='xz'}this.arr[i-1]++}}})
</script>
</html>

优化的代码主要CSS部分,定义了一些样式,包括一个flex布局,用于显示牌子。奇数个牌子的背景色为rebeccapurple,偶数个牌子的背景色为pink。还定义了两个旋转动画xzxzr,用于翻转牌子。这里还定义了一个data属性arr,用于记录每个图片被点击的次数,在methods定义了一个方法xzImg,当点击牌子时触发。根据点击次数的奇偶性,设置不同的背景图像和动画类名,并更新点击次数。v-for指令循环生成6个牌子,并绑定点击事件。randomImgC上节课已经说到了,随机生成图片。

效果图:

2.进入后宫

细心的朋友会发现左上角有一个进入后宫的按钮,下面我们来完成最后一步后宫的所有人物显示:

完整代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>后宫</title><script src="/vue/vue.min.js"></script><script src="/vue/axios.min.js"></script><style>.f{display: flex;justify-content: space-around;flex-wrap: wrap;//换行}.f>div{width: 280px;height: 350px;border: 1px solid rebeccapurple;}.f>div>img{width: 280px;height: 330px;}</style>
</head>
<body>
<div id="app"><div class="f"><div v-for="img in imgNames"><img :src="imgSrc(img)" alt=""><br>{{img}}</div></div>
</div>
</body>
<script>/*在axios的回调函数then中,如果是普通函数function(){this} 普通函数中的this指代js的bom顶层对象,类似java中的Object如果使用箭头函数()=>{this},此时的this表示整个vue实例,也就是new vue({})函数的返回值vueObj*/const vueObj = new Vue({el:'#app',data:{imgNames:[]},methods:{imgSrc(imgName){return '/imgC?action=getImgByName&imgName='+imgName},getAllImgNames(){axios.get('/imgC?action=getAllImgNames').then((resp)=> {this.imgNames=resp.dataconsole.log(resp.data,1,this)})},},mounted(){this.getAllImgNames()//此处的this表示整个vue对象console.log(this.imgNames,2,this)}})console.log(vueObj)
</script>
</html>

效果图:

以下代码的解释:
  • 首先,引入了Vue.js和axios库的脚本文件。
  • 在CSS部分,定义了一些样式,包括一个flex布局,并使用flex-wrap: wrap;实现换行。每个图片容器都有固定的宽度和高度,并设置了边框样式。
  • 在HTML部分,创建了一个Vue实例,绑定到id为app的元素上。
  • 在Vue实例中,定义了一个data属性imgNames,用于存储后宫图片的名称。
  • 定义了一个方法imgSrc,用于根据图片名称动态生成图片的URL。
  • 定义了一个方法getAllImgNames,使用axios发送GET请求获取所有后宫图片的名称,并将返回的数据赋值给imgNames
  • 在mounted钩子函数中调用getAllImgNames方法,实现在Vue实例挂载到DOM后自动获取后宫图片的名称。
  • 最后,在HTML中使用v-for指令循环生成每个图片容器,并显示图片和图片名称。


总结

以上就是今天所讲的全部内容,mounted钩子函数可以调用多种方法,这里我调用了一个,后续需要加其他的函数,直接this.函数名()就可以了。相信通过这两个案例,对响应图片数据的应用有了更深刻的了解。接下来几天我将带大家完成项目坦克风云的设计,让我们继续对java进阶的高峰冲刺吧!

这篇关于娴雅华服舞动间,Java实现后宫佳丽三千,引领世界独具魅力!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/220451

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——