これがコードのjsfiddleです。ページを更新すると Cookie は削除されますが、[実行] を複数回クリックしても問題ありません。
ここにHTMLがあります
<div id="image-form">
<label for="url">Image URL</label>
<input type="text" id="url" value="http://stylegerms.com/wp-content/uploads/2013/06/Techno-Desktop-backgrounds-Desktop-Wallpaper.jpg" />
<input type="button" value="Update" onclick="updateURL()" />
</div>
<!-- Place the JavaScript before </body> -->
必要な JavaScript は次のとおりです。
window.onload = function() {
setBackground();
}
function updateURL() {
var newURL = document.getElementById('url').value;
setCookie('URL', newURL, 365);
document.body.style.background = 'url('+newURL+') no-repeat';
document.body.style.backgroundSize = 'cover';
document.body.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = newURL;
document.body.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").sizingMethod = 'scale';
}
function setBackground() {
var URL = getCookie('URL');
document.body.style.background = 'url('+URL+') no-repeat';
document.body.style.backgroundSize = 'cover';
document.body.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = URL;
document.body.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").sizingMethod = 'scale';
}
function setCookie(c_name, value, exdays) {
var exdate=new Date();
exdate.setDate(exdate.getDate() + exdays);
var c_value=escape(value) + ((exdays==null) ? "" : "; expires="+exdate.toUTCString());
document.cookie=c_name + "=" + c_value;
}
function getCookie(c_name) {
var c_value = document.cookie;
var c_start = c_value.indexOf(" " + c_name + "=");
if (c_start == -1)
c_start = c_value.indexOf(c_name + "=");
if (c_start == -1) {
c_value = null;
} else {
c_start = c_value.indexOf("=", c_start) + 1;
var c_end = c_value.indexOf(";", c_start);
if (c_end == -1)
c_end = c_value.length;
c_value = unescape(c_value.substring(c_start,c_end));
}
return c_value;
}
そして、ここにちょっとしたCSSがあります
html, body {
width: 100%;
height: 100%;
margin: 0;
}
body {
background: url('data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7') no-repeat;
background-size: cover;
-ms-filter: 'progid:DXImageTransform.Microsoft.AlphaImageLoader(src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7", sizingMethod="scale")';
}
#image-form {
display: inline-block;
background: #fff;
padding: 10px;
}