JS實現(xiàn)模仿微博發(fā)布效果實例代碼
更新時間:2013年12月16日 16:56:42 作者:
這篇文章主要介紹了JS實現(xiàn)模仿微博發(fā)布效果實例代碼,有需要的朋友可以參考一下
效果:
思路:
利用多功能浮動運動框架實現(xiàn)微博效果,首先,將textarea中的屬性添加到新創(chuàng)建的li里面然后,再將li添加到ul里面,再利用浮動運動框架將數(shù)據(jù)動態(tài)的顯示出來。
代碼:
復(fù)制代碼 代碼如下:
<head runat="server">
<title></title>
<style type="text/css">
*
{
margin: 0;
padding: 0;
}
#ul1
{
width: 300px;
height: 300px;
border: 1px solid black;
margin: 10px auto;
overflow: hidden;
}
#ul1 li
{
list-style: none;
padding: 4px;
border-bottom: 1px #999 dashed;
overflow: hidden;
opacity: 0;
}
</style>
<script type="text/javascript">
window.onload = function () {
var btn = document.getElementById('btn');
var txt = document.getElementById('t1');
var oUl = document.getElementById('ul1');
btn.onclick = function () {
var cLi = document.createElement('li');
cLi.innerHTML = txt.value; //將數(shù)據(jù)添加到li里面
txt.value = '';
if (oUl.children.length > 0) { //判斷是否已經(jīng)有l(wèi)i,如果有那么就插入,如果沒有那么就新建
oUl.insertBefore(cLi, oUl.children[0]);
} else {
oUl.appendChild(cLi);
}
var iHeight = cLi.offsetHeight; //獲得li的高度
cLi.style.height = '0';
move(cLi, { height: iHeight }, function () { //然后利用浮動運動將數(shù)據(jù)顯示出來
move(cLi, { opacity: 100 });
});
}
}
//------------------------------------------------------------------------------------
//獲取非行間樣式
function getStyle(ojb, name) {
if (ojb.currentStyle) {
return ojb.currentStyle[name];
}
else {
return getComputedStyle(ojb, false)[name];
}
}
//緩沖運動json的應(yīng)用
//json{attr,finsh}
//json{width:200,height:200}
function move(obj, json, fnName) { //obj是對象,Json是對象的屬性, fnName是函數(shù)
clearInterval(obj.timer); //關(guān)閉之前的計時器
obj.timer = setInterval(function () {
var timeStop = true; //記錄屬性是否都已經(jīng)執(zhí)行完成
for (var attr in json) { //遍歷json中的數(shù)據(jù)
var oGetStyle = 0;
if (attr == 'opacity') { //判斷透明度
oGetStyle = Math.round(parseFloat(getStyle(obj, attr)) * 100); //透明度取整,然后轉(zhuǎn)換完后賦值
}
else {
oGetStyle = parseInt(getStyle(obj, attr));
}
var speed = (json[attr] - oGetStyle) / 5; //求速度
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); //進位取整
if (oGetStyle != json[attr])
timeStop = false;
if (attr == 'opacity') { //透明度
obj.style.filter = 'alpha(opacity:' + (oGetStyle + speed) + ')'; //給透明度賦值
obj.style.opacity = (oGetStyle + speed) / 100;
}
else {
obj.style[attr] = oGetStyle + speed + 'px'; //移動div
}
}
if (timeStop) { //如果所有屬性都已經(jīng)執(zhí)行完成,那么就關(guān)閉計時器
clearInterval(obj.timer);
if (fnName) { //當關(guān)閉計時器后要執(zhí)行的函數(shù)
fnName();
}
}
}, 30)
}
//------------------------------------------------------------------------------------
</script>
</head>
<body>
<textarea id="t1"></textarea>
<input type="button" id="btn" value="發(fā)布" />
<ul id="ul1">
<li style="display: none;"></li>
</ul>
</body>
相關(guān)文章
iframe實現(xiàn)與父頁面跨域隔離的JavaScript?代碼沙箱
這篇文章主要介紹了使用iframe實現(xiàn)與父頁面跨域隔離的JavaScript代碼沙箱,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05詳解JavaScript數(shù)組過濾相同元素的5種方法
本篇文章主要介紹了詳解JavaScript數(shù)組過濾相同元素的5種方法,詳細的介紹了5種實用方法,非常具有實用價值,需要的朋友可以參考下2017-05-05JavaScript Event學習第四章 傳統(tǒng)的事件注冊模型
在這一章我會講解給元素注冊事件的最好的一種辦法,那就是:確保一個特定的事件在特定的HTML元素上發(fā)生并且能運行特定的腳本。2010-02-02【經(jīng)驗總結(jié)】編寫JavaScript代碼時應(yīng)遵循的14條規(guī)律
這篇文章主要介紹了編寫JavaScript代碼時應(yīng)遵循的14條規(guī)律,涉及javascript變量的定義,函數(shù)、表單、json的使用,邏輯運算與頁面元素操作技巧等,非常具有實用價值,需要的朋友可以參考下2016-06-06js 實現(xiàn)獲取name 相同的頁面元素并循環(huán)遍歷的方法
下面小編就為大家?guī)硪黄猨s 實現(xiàn)獲取name 相同的頁面元素并循環(huán)遍歷的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02