javascript;Jquery;获取JSON对象,无刷新评论实例。
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<script type="text/javascript">
window.onload = function () {
//注册btn事件
document.getElementById("btnPost").onclick = function () {
var txtTitle = document.getElementById("txtTitle").value;
var txtContent = document.getElementById("txtContent").value;
var txtEmail = document.getElementById("txtEmail").value;
var xhr = null;
if (typeof (XMLHttpRequest) != undefined) {
xhr = new XMLHttpRequest();
}
else {
xhr = new ActiveXObject("Microsoft.XMLHttp");
}
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
var tent = JSON.parse(xhr.responseText);
if (tent.IsOK == "1") {
document.getElementById("fontMsg").innerHTML = "评论成功!";
document.getElementById("fontMsg").color = "green";
//动态添加数据到页面显示
var tbody = document.getElementById("tbody1");
var trobj = tbody.insertRow(-1);
trobj.insertCell(-1).innerHTML = tent.autoId; //编号
trobj.insertCell(-1).innerHTML = txtTitle; //标题
trobj.insertCell(-1).innerHTML = txtContent; //内容
trobj.insertCell(-1).innerHTML = txtEmail; //邮箱
}
else if (tent.IsOK == "0") {
document.getElementById("fontMsg").innerHTML = "评论失败!";
document.getElementById("fontMsg").color = "red";
}
}
};
xhr.open("Post", "AddComments.ashx", true);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.send("title=" + txtTitle + "&content=" + txtContent + "&email=" + txtEmail);
};
//加载评论
var xhr = null;
if (typeof (XMLHttpRequest) != undefined) {
xhr = new XMLHttpRequest();
}
else {
xhr = new ActiveXObject("Microsoft.XMLHttp");
}
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
var Comments = JSON.parse(xhr.responseText);
var tbody = document.getElementById("tbody1");
for (var i = 0; i < Comments.length; i++) {
var trobj = tbody.insertRow(-1);
trobj.insertCell(-1).innerHTML = Comments[i].autoId;
trobj.insertCell(-1).innerHTML = Comments[i].title;
trobj.insertCell(-1).innerHTML = Comments[i].content;
trobj.insertCell(-1).innerHTML = Comments[i].email;
}
}
};
xhr.open("Get", "GetComments.ashx", true);
xhr.send(null);
};
</script>
</head>
<body>
评论:<br />
<table border="1">
<tr>
<td>标题:</td>
<td><input type="text" id="txtTitle" value="" /></td>
</tr>
<tr>
<td>内容:</td>
<td><input type="text" id="txtContent" value="" /></td>
</tr>
<tr>
<td>邮箱:</td>
<td><input type="text" id="txtEmail" value="" /></td>
</tr>
<tr>
<td></td>
<td><input type="button" id="btnPost" value="评论" /><font id="fontMsg"></font></td>
</tr>
</table>
<p>=========================================================</p>
<table>
<tr>
<td>编号:</td>
<td>标题:</td>
<td>内容:</td>
<td>邮箱:</td>
</tr>
<tbody id="tbody1"></tbody>
</table>
</body>
</html>
一般处理程序:
using MyPerson.BLL;
using MyPerson.Model;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Script.Serialization; namespace MyPerson.UI.Ajax
{
/// <summary>
/// AddComments 的摘要说明
/// </summary>
public class AddComments : IHttpHandler
{ public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request["title"] != null && context.Request["content"] != null && context.Request["email"] != null)
{
TblComments model = new TblComments();
model.title = context.Request["title"];
model.content = context.Request["content"];
model.email = context.Request["email"];
int n = new CommentsBll().AddComment(model);
string json = new JavaScriptSerializer().Serialize(new { autoId = n, IsOK = n > ? : }); //匿名类
context.Response.Write(json);
}
} public bool IsReusable
{
get
{
return false;
}
}
}
}
jquery版:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<script src="../Scripts/jquery-1.7.1.js"></script>
<script type="text/javascript">
$(function () {
//注册btn事件
$("#btnPost").click(function () {
var txtTitle = $("#txtTitle").val();
var txtContent = $("#txtContent").val();
var txtEmail = $("#txtEmail").val();
$.getJSON("AddComments.ashx", { "title": txtTitle, "content": txtContent, "email": txtEmail }, function (_data) {
if (_data.IsOK == "1") {
$("#fontMsg").html("评论成功!");
$("#fontMsg").css("color", "green");
//动态添加数据到页面显示
var tr = $("<tr><td>" + _data.autoId + "</td><td>" + txtTitle + "</td><td>" + txtContent + "</td><td>" + txtEmail + "</td></tr>");
$("#tbody1").append(tr);
}
else if (_data.IsOK == "0") {
$("#fontMsg").html("评论失败!");
$("#fontMsg").css("color", "red");
}
});
});
//加载评论
$.getJSON("GetComments.ashx", null, function (_data) {
$.each(_data, function (key, value) {
var tr = $("<tr><td>" + value.autoId + "</td><td>" + value.title + "</td><td>" + value.content + "</td><td>" + value.email + "</td></tr>");
$("#tbody1").append(tr);
});
});
});
</script>
</head>
<body>
评论:<br />
<table border="1">
<tr>
<td>标题:</td>
<td><input type="text" id="txtTitle" value="" /></td>
</tr>
<tr>
<td>内容:</td>
<td><input type="text" id="txtContent" value="" /></td>
</tr>
<tr>
<td>邮箱:</td>
<td><input type="text" id="txtEmail" value="" /></td>
</tr>
<tr>
<td></td>
<td><input type="button" id="btnPost" value="评论" /><font id="fontMsg"></font></td>
</tr>
</table>
<p>=========================================================</p>
<table>
<tr>
<td>编号:</td>
<td>标题:</td>
<td>内容:</td>
<td>邮箱:</td>
</tr>
<tbody id="tbody1"></tbody>
</table>
</body>
</html>
javascript;Jquery;获取JSON对象,无刷新评论实例。的更多相关文章
- javascript;Jquery;获取JSON对象,无刷新分页,异步加载,异步删除,实例。
AjaxNewsList: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> < ...
- jquery获取json对象中的key小技巧
jquery获取json对象中的key小技巧 比如有一个json var json = {"name" : "Tom", "age" : 1 ...
- JQuery 获取json数据$.getJSON方法的实例代码
这篇文章介绍了JQuery 获取json数据$.getJSON方法的实例代码,有需要的朋友可以参考一下 前台: function SelectProject() { var a = new Array ...
- asp.net中利用Jquery+Ajax+Json实现无刷新分页(二)
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="PageTest.aspx.cs ...
- ajax分页2:jquery.pagination +JSON 动态无刷新分页
静态页面: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...
- jquery获取json对象中的key小技巧,遍历json串所有key,value
比如有一个json var json = {"name" : "Tom", "age" : 18}; 想分别获取它的key 和 value ...
- jquery.pagination +JSON 动态无刷新分页
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="SqlPage.aspx.cs& ...
- javascript获取json对象的key名称的两种方法
javascript获取json对象的key名称的两种方法 数据处理中,你可能接收到一个不确定内容格式的json对象,然后要把key的值提取出来.今天试过两种可以提取json key的方法,均可以正常 ...
- jQuery 无刷新评论
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- 实战Jquery(二)--能够编辑的表格
今天实现的是一个表格的样例,通过获取表格的奇数行,设置背景色属性,使得奇偶行背景色不同.这个表格能够在单击时编辑,回车即更改为新输入的内容;ESC还原最初的文本.表格的实现思路非常清晰,仅仅是在实现的 ...
- deque双端队列用法
#include <iostream> #include <cstdio> #include <deque> #include <algorithm> ...
- 挂载samb目录
不管是ubuntu还是fedora文件管理器都带有挂载浏览smb目录的工具,但是我却找不到它的挂载点,所以想用命令行拷贝东西就没办法了,还是需要使用传统的挂载方式, mount -t cifs -o ...
- apache2+svn Expected FS format '2'; found format '3'
format格式与svn版本号我猜对应如下: 1.4.x 对应 format 2 1.5.x 对应 format 3 …… 1.8.x 对应 format 6 那么每个format创建出的repo要用 ...
- 检测手机中是否安装了google地图,没有则提示安装,并跳转到地图查找特定的地点
/** * 检测手机中是否安装了某个特定的app,若没有提示安装 */ PackageInfo name_2 = null; try { // 若没有这个包名会异常 name_2 = getPacka ...
- OpenCV学习笔记十一:opencv_ocl模块
一,简介: 基于OpenCL优化的代码.
- 那些可爱的 Linux 命令
环境 root@15b883:~# uname -a ##需要是Ubuntu环境 Linux 15b883 --generic #- :: UTC x86_64 x86_64 x86_64 GNU/L ...
- idea 全部报错找不到包
解决报错方法如下:
- Windows Azure 免费初体验 - 创建部署网站
前几天在看到有个学Windows Azure课程,送Windows Azure的活动,课程地址:http://www.microsoftvirtualacademy.com/ 在活得体验资格后,就迫不 ...
- WPF中DPI的问题
先搞清楚一下几个概念: DPI:dots per inch ,每英寸的点数.我们常说的鼠标DPI,是指鼠标移动一英寸的距离滑过的点数:打印DPI,每英寸的长度打印的点数:扫描DPI,每英寸扫描了多 ...