1
シンプルウェザーjsを使用して天気アプリを作ろうとしています。私は正常に私の現在の場所の天気を表示するアプリを得ることができましたが、私は天気のアイコンを温度の隣に表示する方法をよく分かりません。どんな助けでも大歓迎です。 は、ここに私のcodepenです:http://codepen.io/perrylivingston/pen/dMLLOP これらは私が使用しようとしているアイコンです:https://github.com/erikflowers/weather-iconsシンプルウェザーjs weatherアイコン
HTML:
<div id="the_weather"></div>
<button class="js-geolocation"> Use Location</button>
<i class="wi wi-yahoo-31"></i>
CSS:
body {
background-image: url("http://www.psdgraphics.com/file/blue-sky.jpg");
background-size: cover;
height: 100%;
width: 100%;
}
#the_weather {
width: 500px;
text-align: center;
margin: 0px auto;
text-transform: uppercase;
}
@font-face {
src: url('weathericons-regular-webfont.eot') format ('embedded-opentype');
src: url('weathericons-regular-webfont.svg') format ('svg');
src: url('weathericons-regular-webfont.ttf') format('truetype');
src: url('weathericons-regular-webfont.woff') format('woff');
src: url('weathericons-regular-webfont.woff2') format('woff2');
}
i {
color: #ffffff;
font-size: 160px;
font-weight: normal;
font-style: normal;
}
#the_weather li {
display: block;
font-weight: bold;
padding: 5px;
}
.icon-0:before { content: ":"; }
.icon-1:before { content: "p"; }
.icon-2:before { content: "S"; }
.icon-3:before { content: "Q"; }
.icon-4:before { content: "S"; }
.icon-5:before { content: "W"; }
.icon-6:before { content: "W"; }
.icon-7:before { content: "W"; }
.icon-8:before { content: "W"; }
.icon-9:before { content: "I"; }
.icon-10:before { content: "W"; }
.icon-11:before { content: "I"; }
.icon-12:before { content: "I"; }
.icon-13:before { content: "I"; }
.icon-14:before { content: "I"; }
.icon-15:before { content: "W"; }
.icon-16:before { content: "I"; }
.icon-17:before { content: "W"; }
.icon-18:before { content: "U"; }
.icon-19:before { content: "Z"; }
.icon-20:before { content: "Z"; }
.icon-21:before { content: "Z"; }
.icon-22:before { content: "Z"; }
.icon-23:before { content: "Z"; }
.icon-24:before { content: "E"; }
.icon-25:before { content: "E"; }
.icon-26:before { content: "3"; }
.icon-27:before { content: "a"; }
.icon-28:before { content: "A"; }
.icon-29:before { content: "a"; }
.icon-30:before { content: "A"; }
.icon-31:before { content: "6"; }
.icon-32:before { content: "1"; }
.icon-33:before { content: "6"; }
.icon-34:before { content: "1"; }
.icon-35:before { content: "W"; }
.icon-36:before { content: "1"; }
.icon-37:before { content: "S"; }
.icon-38:before { content: "S"; }
.icon-39:before { content: "S"; }
.icon-40:before { content: "M"; }
.icon-41:before { content: "W"; }
.icon-42:before { content: "I"; }
.icon-43:before { content: "W"; }
.icon-44:before { content: "a"; }
.icon-45:before { content: "S"; }
.icon-46:before { content: "U"; }
.icon-47:before { content: "S"; }
#weather h2 {
margin: 0 0 8px;
color: #fff;
font-size: 100px;
font-weight: 300;
text-align: center;
text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
}
#weather ul {
margin: 0;
padding: 0;
}
#weather li {
background: #fff;
background: rgba(255,255,255,0.90);
padding: 20px;
display: inline-block;
border-radius: 5px;
は、 }
#weather .currently {
margin: 0 20px;
}
button {
display: block;
margin: 15px auto;
width: 140px;
padding: 5px;
background:#efcc3a;
color: #0;
font-weight: bold;
border: 0;
border-radius: 5px;
}
jQueryの場合(ナビゲータで "ジオロケーション"){ $( 'JS-ジオロケーション。')を表示()。 } else { $( 'js-geolocation')。hide(); }
$('.js-geolocation').on('click', function() {
navigator.geolocation.getCurrentPosition(function(position) {
loadWeather(position.coords.latitude+','+position.coords.longitude);
});
});
$(document).ready(function() {
loadWeather('New York','');
});
function loadWeather(location, woeid) {
$.simpleWeather({
location: location,
woeid: woeid,
unit: 'f',
success: function(weather) {
html = '<h2><i class="icon-'+weather.code+'"></i> '+weather.temp+'°'+weather.units.temp+'</h2>';
html += '<ul><li>'+weather.city+', '+weather.region+'</li>';
html += '<li class="currently">'+weather.currently+'</li>';
html += '<li>'+weather.alt.temp+'°C</li></ul>';
$("#the_weather").html(html);
},
error: function(error) {
$("#the_weather").html('<p>'+error+'</p>');
}
});
}
アイコンの互換性ページ(https://erikflowers.github.io/weather-icons/api-list.html)によると、 'wi-yahoo-31'に相当するのは' night-clear'なので 'あなたは ''を使うでしょう - アイコンに 'weather.code'を追加するのではなく、ルックアップテーブル(天気アイコンを使ってyahooのアイコンをマッピングする)を使用し、毎回置き換えを使用します。それは理にかなっていますか? – ochi
そうだと思います。しかし、コードが現れたので、私はCSSで文字のプレースホルダを取得しています。新しいアイコンにマッピングする前に、ヤフーアイコンを表示させるにはどうすればいいですか?私はこれまでにをHTMLで成功させました。私は行方不明のものがありますか?コードペンに –
、天気アイコンのCSSを含めていますか? (私があなたのペンを修正すると、夜のクリアアイコン(左下、中央にない)が表示されます – ochi