前端必学!vue实现打星评分

vue实现打星评分功能

//首先引用vue.js
<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.11/vue.js"></script>

然后设置vue

<script>
    let vm = new Vue({
        el: '#app',
        data() {
            return {
                score1:2,
                score:2,
                count:10
            }
        },
    })
</script>

开始设置星星显示

<div id="app">
	//通过v-for的循环,显示出了10个星星   PS(我用的是iconfont,大家使用前记得要link引入)
    <i v-for="order in count" class="iconfont iconxingxing1" aria-hidden="true"></i>
</div>

在这里插入图片描述
这个时候只是循环出了指定个数count的星星

//修改i标签 @mouseenter当鼠标触碰是,将score1更改为鼠标当前所在的order
//再更改class,添加一个绑定class,进行判断,order小于等于score1的时候,显示iconshoucang1的图标,否则反之
//这样,触碰时更改score1,触碰到底几颗星,从左开始第一颗到鼠标触碰的那一刻变成红色的星
<i v-for="order in count" class="iconfont" @mouseenter="score1=order"
 :class="order<=score1?'iconshoucang1':'iconxingxing1'" ></i>

在这里插入图片描述
但是这时有问题,鼠标只是触碰到,但是并没有点击,星星就变了,所以得加以下代码

//@mouseleave 鼠标离开时score1的值改为score,这时就体现了score的作用,在只是触碰没点击时,星星变成之前的数量
<i v-for="order in count" class="iconfont" @mouseenter="score1=order"
 :class="order<=score1?'iconshoucang1':'iconxingxing1'" 
 @mouseleave="score1 = score"></i>

再加一个点击事件,就完成了

//@click点击后score的值变为order
<i v-for="order in count" class="iconfont" @mouseenter="score1=order"
 :class="order<=score1?'iconshoucang1':'iconxingxing1'" 
 @mouseleave="score1 = score"  @click="score=order"></i>
  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Vue前端打印的方法有多种。其中一种方法是通过引入打印插件来实现。你可以在后台功能中查询合适的插件并进行下载,然后在前端中使用该插件来进行打印操作。 另外,需要注意的是在处理打印逻辑之前,要确保样式已经正确引入,否则打印的页面可能会没有样式。你可以单独引入一个print.scss文件或者使用@media print {}来调整一些样式。这样可以确保打印页面的样式与预期一致。 如果打印的内容中包含线上图片资源,并且你不想进行服务器配置,可以考虑在浏览器关闭获取缓存文件的方式来解决。这样可以保证每一次获取的都是线上文件,避免打印时出现图片跨域的错误。需要注意的是,前端无法获取你点击打印或者取消的事件,只能获取你是否关闭打印框的事件。 综上所述,你可以通过下载适合的打印插件来实现Vue前端打印功能,并在处理打印逻辑前确保样式已正确引入。如果打印内容中包含线上图片资源,可以通过浏览器关闭获取缓存文件的方式来避免跨域错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue 前端实现打印功能](https://blog.csdn.net/m0_64344940/article/details/128405517)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [vue前端实现打印功能](https://blog.csdn.net/love521334421/article/details/125163942)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值