<!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对象,无刷新评论实例。的更多相关文章

  1. javascript;Jquery;获取JSON对象,无刷新分页,异步加载,异步删除,实例。

    AjaxNewsList: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> < ...

  2. jquery获取json对象中的key小技巧

    jquery获取json对象中的key小技巧 比如有一个json var json = {"name" : "Tom", "age" : 1 ...

  3. JQuery 获取json数据$.getJSON方法的实例代码

    这篇文章介绍了JQuery 获取json数据$.getJSON方法的实例代码,有需要的朋友可以参考一下 前台: function SelectProject() { var a = new Array ...

  4. asp.net中利用Jquery+Ajax+Json实现无刷新分页(二)

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="PageTest.aspx.cs ...

  5. ajax分页2:jquery.pagination +JSON 动态无刷新分页

    静态页面: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...

  6. jquery获取json对象中的key小技巧,遍历json串所有key,value

    比如有一个json var json = {"name" : "Tom", "age" : 18}; 想分别获取它的key 和 value ...

  7. jquery.pagination +JSON 动态无刷新分页

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="SqlPage.aspx.cs& ...

  8. javascript获取json对象的key名称的两种方法

    javascript获取json对象的key名称的两种方法 数据处理中,你可能接收到一个不确定内容格式的json对象,然后要把key的值提取出来.今天试过两种可以提取json key的方法,均可以正常 ...

  9. jQuery 无刷新评论

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. HDU - 5301 Buildings

    Buildings Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total S ...

  2. xilinx 赛灵思fpga verilog hdl 教程

    http://www.eefocus.com/article/08-03/37231s.html http://wenku.baidu.com/link?url=5mdkMmm4BGGi7gRdgSk ...

  3. Android 编程之入门开发目录管理器开发抽屉与文件分类-4

    在此目录管理APP里,我们能够尝试引用一些新的元素.在这里我给打击介绍一个叫抽屉的布局,QQ就用到了抽屉布局.不 过他们又在原有的基础上自己开发了新的抽屉布局.而且还蛮高大上的,顺便说说分类管理.这些 ...

  4. 1254 Problem V

    问题 V: 光棍的yy 时间限制: 1 Sec  内存限制: 128 MB 提交: 42  解决: 22 [提交][状态][讨论版] 题目描述 yy经常遇见一个奇怪的事情,每当他看时间的时候总会看见1 ...

  5. 如何顺利解决mac下命令不管用的情况

    背景: 昨晚通过brew安装了node,结果导致我的终端除了cd和ls管用外,其他的命令都不管用了,网上搜索了一大堆,结果没有一个能正确解决我的问题的,记录一下吧. 打开终端就显示: -bash: t ...

  6. 如何停止和扭转UIView的动画

    本文转载至  http://codego.net/576089/ 我有它收缩时碰到切换按钮UIView的动画跳和它扩展恢复到原来的大小当再次接触到按钮.密封式前大灯一切都工作得很好.问题是,动画师注意 ...

  7. CodeIgniter框架——源码分析之Config.php

    CI框架的配置信息被存储在$config数组中,我们可以添加自己的配置信息或配置文件到$config中: $this->config->load('filename'); //加载配置文件 ...

  8. 内核源码阅读vim+cscope+ctags+taglist

    杜斌博客:http://blog.db89.org/kernel-source-read-vim-cscope-ctags-taglist/ 武特博客:http://edsionte.com/tech ...

  9. 【BZOJ1941】[Sdoi2010]Hide and Seek KDtree

    [BZOJ1941][Sdoi2010]Hide and Seek Description 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了 ...

  10. 【RSS】我的RSS使用介绍

    早就想写一个有关RSS的文章,一直没时间,今天刚好被现DL说了一波,那就先整理出一篇教程吧.后续说不定还有分享: 分享相关PPT: 一.我使用的服务: Feedly:https://feedly.co ...