vue加载天气组件

天气插件

中国天气网

vue中使用

首先我们进入中国天气网生成一段代码
根据需要设置天气样式
在这里插入图片描述
在这里插入图片描述
复制并修改生成的这段代码到vue中

将script引入 修改为vue的动态引入方法

<template>
    <div id="weater">
        <div id="weather-view-he" ref="weather"></div>
        <remote-script src="天气网生成代码中script的src"></remote-script>
    </div>
</template>
<script>
window.WIDGET = {ID: '123456'};   // 将WIDGET前边加上window 否则读取不到此变量
import Vue from 'vue'
Vue.component('remote-script', {   // vue动态生成script (在html中当成组件来用)
    render: function (createElement) {
        var self = this;
        return createElement('script', {
            attrs: {
                type: 'text/javascript',
                src: this.src
            },
            on: {
                load: function (event) {
                    self.$emit('load', event);
                },
                error: function (event) {
                    self.$emit('error', event);
                },
                readystatechange: function (event) {
                    if (this.readyState == 'complete') {
                        self.$emit('load', event);
                    }
                }
            }
        });
    },
    props: {
        src: {
            type: String,
            required: true
        }
    }
})
export default {
    name:"Weather",
    data(){
        return {
           
        }
    },
}
</script>
  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Vue实现动态天气效果可以通过以下步骤实现: 1. 获取天气数据:使用Vue的Axios库或者Fetch API来从天气API获取实时天气数据。根据API的要求,发送HTTP请求获取天气信息的JSON数据。 2. 解析天气数据:将获取到的JSON数据解析成可用的对象。根据需要,可以提取出温度、湿度、天气状况等关键信息。 3. 使用Vue的计算属性:将解析得到的天气数据保存在Vue组件的计算属性中,以便在模板中动态地渲染天气信息。 4. 渲染天气效果:根据解析得到的天气数据,在Vue模板中使用条件渲染和循环渲染来展示不同的天气效果。可以使用Vue的指令来根据天气状态变化来应用不同的样式。 5. 实时更新天气数据:使用Vue的定时器或者WebSocket等技术来定期或者实时地更新天气数据。在定时器回调函数中,重新发送HTTP请求获取最新的天气数据,然后更新Vue组件中的计算属性。 6. 添加动态效果:通过使用Vue的过渡效果或者Vue动画库,可以给天气组件添加一些动态效果,比如渐变、滚动、飘雪等效果,增强用户体验。 7. 错误处理:考虑到络请求可能失败或者天气API可能返回错误的数据,需要在Vue组件中添加错误处理逻辑,如显示错误信息或者提供重新加载按钮。 以上是实现动态天气效果的主要步骤。通过合理利用Vue的响应式数据绑定、计算属性、条件渲染等特性,可以实现一个动态并且用户友好的天气展示组件
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值