html ajax 网页评论,appendHTML方法ajax加载更多评论实例页面

//在后添加

var appendHTML = function(el, html) {

var divTemp = document.createElement("ul"), nodes = null

, fragment = document.createDocumentFragment();

divTemp.innerHTML = html;

nodes = divTemp.childNodes;

for (var i=0, length=nodes.length; i < length; i+=1) {

fragment.appendChild(nodes[i].cloneNode(true));

}

el.appendChild(fragment);

// 据说下面这样子世界会更清净

nodes = null;

fragment = null;

};

var $ = function(id) {

return {

0: document.getElementById(id),

length: 1,

click: function(fn) {

this[0].onclick = fn;

},

appendHTML: function(html, where) {

appendHTML(this[0], html, where);

}

}

};

$("commentMore").click(function() {

var xhr, self = this;

if (this.ajaxing) return;

if (window.XMLHttpRequest) {

xhr = new window.XMLHttpRequest();

} else {

xhr = new ActiveXObject("Microsoft.XMLHttp");

}

// 提示

this.innerHTML = '加载中...';

// 阻止二次点击

this.ajaxing = true;

// ajax go go go!

xhr.open("get", this.getAttribute("data-url"), true);

xhr.send(null);

xhr.onreadystatechange = function() {

if (xhr.readyState === 4) {

if (xhr.status === 200 && xhr.responseText) {

$("commentUl").appendHTML(xhr.responseText);

self.parentNode.innerHTML = '全部加载完毕';

self = null;

} else {

self.innerHTML = '加载失败!点击重试~';

self.ajaxing = false;

}

}

}

return false;

});

//在前添加

var prependHTML = function(el, html) {

var divTemp = document.createElement("ul"), nodes = null

, fragment = document.createDocumentFragment();

divTemp.innerHTML = html;

nodes = divTemp.childNodes;

for (var i=0, length=nodes.length; i < length; i+=1) {

fragment.appendChild(nodes[i].cloneNode(true));

}

el.insertBefore(fragment, el.firstChild);

// 据说下面这样子世界会更清净

nodes = null;

fragment = null;

};

var $ = function(id) {

return {

0: document.getElementById(id),

length: 1,

click: function(fn) {

this[0].onclick = fn;

},

prependHTML: function(html, where) {

prependHTML(this[0], html, where);

}

}

};

$("commentMore").click(function() {

var xhr, self = this;

if (this.ajaxing) return;

if (window.XMLHttpRequest) {

xhr = new window.XMLHttpRequest();

} else {

xhr = new ActiveXObject("Microsoft.XMLHttp");

}

// 提示

this.innerHTML = '加载中...';

// 阻止二次点击

this.ajaxing = true;

// ajax go go go!

xhr.open("get", this.getAttribute("data-url"), true);

xhr.send(null);

xhr.onreadystatechange = function() {

if (xhr.readyState === 4) {

if (xhr.status === 200 && xhr.responseText) {

$("commentUl").prependHTML(xhr.responseText);

self.parentNode.innerHTML = '全部加载完毕';

self = null;

} else {

self.innerHTML = '加载失败!点击重试~';

self.ajaxing = false;

}

}

}

return false;

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值