当我改变div的innerHTML时,我正试图做fadein / out效果。甚至在safari doc
给出了尝试过的例子我希望div淡出,更改内容,然后再次使用新内容淡入。
<style>
.cv { background-color: #eee; -webkit-transition: all 1s ease-in-out;}
.cf {opacity: 0;}
</style>
<body>
<div id="main">
<div id="c"> OLD </div>
</div>
</body>
<script>
var c = document.getElementById("c");
c.setAttribute("class", "cf");
c.innerHTML = '';
c.appendChild(fragment);
c.setAttribute("class", "cv");
</script>
请在这里帮助我
答案 0 :(得分:2)
<style>
.cv { opacity:1; background-color: #eee; -webkit-transition: all 1s ease-in-out;}
.cv.hide {opacity: 0;}
</style>
[...]
<script>
c.setAttribute("class", "cv hide");
[...]
c.setAttribute("class", "cv");
</script>
答案 1 :(得分:1)
我重新编写了代码 - 请参阅http://jsfiddle.net/Kai/ec64b/
我还提供了一些类操作函数供您使用。
答案 2 :(得分:0)
<style>
.cv { background-color: #eee; -webkit-transition: all 1s ease-in-out;}
/* .cf {opacity: 0;} */
</style>
<body>
<div id="main">
<div id="c"> OLD </div>
</div>
<script>
var c = document.getElementById("c");
c.setAttribute("class", "cf");
// c.innerHTML = '';
// c.appendChild(fragment);
c.setAttribute("class", "cv");
</script>
</body>
试试这段代码。将脚本置于正文结束标记之前,而不是之后。
答案 3 :(得分:0)
这是我最终结束的事情。谢谢大家的答案
init: function(fragment) {
var c = document.getElementById("c");
c.addEventListener( 'webkitTransitionEnd', IDR.callHook(c, fragment), false);
c.setAttribute("class", "cv hide");
},
callHook: function(c, fragment) {
var fp = function() {
c.removeEventListener('webkitTransitionEnd', fp, false);
c.innerHTML = '';
c.setAttribute("class", "cv");
c.appendChild(fragment);
};
return fp;
},