首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何缓存forecast.io api数据

如何缓存forecast.io api数据
EN

Stack Overflow用户
提问于 2015-09-04 22:35:57
回答 1查看 570关注 0票数 1

我使用jquery和forecast.io在我的magento网站的管理部分获取天气数据。

我想知道如何缓存一定时间的数据,这样我就可以减少所做的api数据请求的数量。这样,只有在缓存时间用完之后才会请求新数据。

代码语言:javascript
复制
<script>
            var $j = jQuery.noConflict();

            $j(document).ready(function(){
                var apiKey = 'API KEY';
                //Go to forecast.io get your free API Key
                var curl = 'https://api.forecast.io/forecast/';
                var lati = 37.8267;
                var longi = -122.423;
                var data;
                $j.ajax({
                    type: "GET",
                    url: curl + apiKey +"/"+ lati +","+ longi +"?callback=?",
                    dataType: "json",
                    success: function(data){
                        //var json = $j.parseJSON(data);
                        console.log(data);
                        $j("#currentTemperature").append(Math.floor(data.currently.temperature));
                        $j("#currentTime").append(Date(data.currently.time));
                        if(data.currently.icon == 'clear-day') { $j("#clear-day").css("display", "block")};
                        if(data.currently.icon == 'clear-night') { $j("#clear-night").css("display", "block")};
                        if(data.currently.icon == 'rain') { $j("#rain").css("display", "block")};
                        if(data.currently.icon == 'snow') { $j("#snow").css("display", "block")};
                        if(data.currently.icon == 'sleet') { $j("#sleet").css("display", "block")};
                        if(data.currently.icon == 'wind') { $j("#wind").css("display", "block")};
                        if(data.currently.icon == 'fog') { $j("#fog").css("display", "block")};
                        if(data.currently.icon == 'cloudy') { $j("#cloudy").css("display", "block")};
                        if(data.currently.icon == 'partly-cloudy-day') { $j("#partly-cloudy-day").css("display", "block")};
                        if(data.currently.icon == 'partly-cloudy-night') { $j("#partly-cloudy-night").css("display", "block")};
                        if(data.currently.icon == 'hail') { $j(".currentIcon").css("display", "block")};
                        if(data.currently.icon == 'thunderstorm') { $j(".currentIcon").css("display", "block")};
                        if(data.currently.icon == 'tornado') { $j(".currentIcon").css("display", "block")};


                        $j("#humidity").append(data.currently.humidity);
                        $j("#currentWind").append(data.currently.windSpeed);
                        $j("#hourlySummary").append(data.hourly.summary);
                        $j("#currentSummary").append(data.currently.summary);
                        $j("#daily_summary").append(data.daily.summary);
                        $j("weekly").append(data.daily.data[0].apparentTemperatureMax);
                    },
                    error: function() {
                        alert("An error occurred");
                    }


                });
            });
        </script>
        <div class="weather-widget">
            <h4 class="wwl-title">Place</h4>
            <div class="row">
                <figure class="icons">
                    <canvas id="clear-day"  width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="clear-night" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="partly-cloudy-day" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="partly-cloudy-night" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="cloudy" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="rain" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="sleet" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="snow" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="wind" width="140" height="140" style="display: none;">
                    </canvas>

                    <canvas id="fog" width="140" height="140" style="display: none;">
                    </canvas>

                </figure>
                <div class="temp-feed">
                    <h1 class="temp"><span id="currentTemperature"></span><i class=" wi wi-fahrenheit"></i></h1>
                    <div class="summdetail">
                        <small id="currentSummary"></small></br>
                        <span id="currentWind" class=" wi wi-strong-wind"></span><span>mph</span></br>
                        <span id="dayIcon"></span>
                    </div>
                </div>
            </div><!-- /.row -->
        </div>

有人能告诉我怎么做吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-04 23:32:59

获取数据并将其赋值给变量:

代码语言:javascript
复制
 var weather_obj = {};
 weather.temp = data_return_from_api_call.temp;

将您想要作为成员存储的所有变量赋值,就像我前面对temp所做的那样。在需要数据的代码中,您可以在任何地方使用该obj。

在启动页面时,启动一个计时器。

代码语言:javascript
复制
 setInterval(function(){ alert("Hello"); }, 3000);

在“警报”(“Hello”)所在的位置,编写检索数据的代码。这将设置一个定时器,它将以设定的间隔运行该函数,在示例中每3000毫秒,即3秒。这将每隔几秒钟更新一次对象中的值。只要页面在桌面上打开,它将继续运行此定时器。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32407506

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档