前端javascript发送ajax请求、后台书写function小案例
HTML端页面:
<td>
<input class="pp_text" type="text" name="" value="{$info.bar_code}" id="txtBarcode" style="float: left;"/>
<input class="tj-button tj-button2" onclick="search_bar_code({$info.goods_id})" type="button" value="确定" />
</td>
javascript页面(我发现在所有HTML也好,javascriot页面也好,这个ThinkPHP之中的U方法的写法,"{:U('goods/add')}"都是通用的;)
<script type="text/javascript">
function search_bar_code(id)
{ //根据条形码搜索商品信息
var bar_code = parseInt($('#txtBarcode').val());
$.ajax({
url:"{:U('Goods/search_bar_code')}",
type:'post',
dataType:'json',
data:{'id':id,'bar_code':bar_code},
success:function(res){
if(res.notice == 'ok' && res.html){
$('#goodsForm').html(res.html);
}else{
alert(res.notice);
}
}
});
}
</script>
现在看看后台的接口程序如何写
/* 根据条形码找出商品信息 */
function search_bar_code()
{
if(IS_AJAX){
$input = I('post.');//接受ajax传递过来的post数据
$id = intval($input['id']);//转整型
$bar_code = intval($input['bar_code']);
$service_id = $_SESSION['service_site']['service_id'];
$g = D('goods');
$info = $g->where("bar_code = $bar_code")->find();
$res = array('notice'=>'ok');//
$tmp_img = array();
$info['goods_id'] = $id;
//取出供应商与栏目列表end
$this->assign('info',$info);
$html = $this->fetch('goods_ajax');
$res['html'] = $html;
}else{
$res['notice'] = '没有该条形码信息';
}
$this->ajaxReturn($res,'JSON');
}
}
第17行的goods_ajax是一个静态HTML模板;fetch的作用的返回已经渲染好的HTML的代码;而display是直接输出渲染号的HTML的代码;
其中的goods_ajax的,只是当前HTML页面需要被刷新的一部分,比如一个table
如下
<table class="splr_table" width="100%" cellpadding="0" cellspacing="0">
<tr>
<td align="right">按条形码搜索:</td>
<td>
<input class="pp_text" type="text" name="" value="{$info.bar_code}" id="txtBarcode" style="float: left;" />
<input class="tj-button tj-button2" onclick="search_bar_code({$info.goods_id})" type="button" id="btnMatch" value="确定" style="margin-top: 0px; margin-bottom: 0px;" />
</td>
</tr>
<div class="shop_div">
<select id="category_three1" name="data[category_3]" class="splr_select">
<option value="0">请选择一级分类</option>
<foreach name="category_3" item="v">
<option value="{$v.category_id}" <?php if($v['category_id'] == $info['category_3']){echo 'selected';} ?> >{$v.category_name}</option>
</foreach>
</select>
</div>
</td>
</tr>
<tr>
<td align="right"><span class="red">*</span>商品名称:</td>
<td>
<div class="oper-find" style="position: relative;">
<input name="data[goods_name]" class="sp_name relation_store" value="{$info.goods_name}" type="text" placeholder="请输入/选择商品名称" />
</div>
</td>
</tr>
你只需要记住,接口是如何返回数据,如何发送请求给接口函数的,然后又是如何将返回的数据用于局部刷新的
再上一个小小的接口程序:
这次返回的数据比较小;
/* 处理ajax返回的数据 */
function set_goods_ajax()
{
if(IS_AJAX){
$input = I('post.');
$id = intval($input['goods_id']);
$data = $input['data'];
$service_id = $_SESSION['service_site']['service_id'];
$where = "goods_id = $id and service_id = $service_id";
$g = D('goods');
$allow_field = array('status','listorder','is_best');
foreach($data as $k=>$v){ //过滤非法字段,虽然有点多余
if(!in_array($k,$allow_field)){
unset($data[$K]);
}
}
$f = $g->where($where)->save($data);
if($f){
$res = array('notice'=>'ok');
}else{
$res = array('notice'=>'修改失败!');
}
$this->ajaxReturn($res,'JSON');
}
}
前端javascript发送ajax请求、后台书写function小案例的更多相关文章
- easyUi 学习笔记 (二 ) 使用tabs 里datagridview 发送ajax请求 不访问后台的问题
这个BUG 我花了一个半小时, 还是看不出哪里的问题, 于是就百度到这么一段话,我需要记住 <================================================= ...
- C# 动态创建SQL数据库(二) 在.net core web项目中生成二维码 后台Post/Get 请求接口 方式 WebForm 页面ajax 请求后台页面 方法 实现输入框小数多 自动进位展示,编辑时实际值不变 快速掌握Gif动态图实现代码 C#处理和对接HTTP接口请求
C# 动态创建SQL数据库(二) 使用Entity Framework 创建数据库与表 前面文章有说到使用SQL语句动态创建数据库与数据表,这次直接使用Entriy Framwork 的ORM对象关 ...
- Jquery发送ajax请求以及datatype参数为text/JSON方式
Jquery发送ajax请求以及datatype参数为text/JSON方式 1.方式一:datatype:'text' 2.方式二:datatype:'JSON' 3.使用gson-1.5.jar包 ...
- C#WebForm里面aspx,ajax请求后台。。。
虽然WebForm里面有那些基本控件,后台CS里面也有许许多多的控件的方法.但是不见得有些标签不需要进行后台的访问,下面介绍一下三种aspx中访问后台的方式.. 第一种:WebMethod (静态方法 ...
- 发送ajax请求时候注意的问题
1.在发送ajax请求一般都是默认为异步,就是不去等待后台响应直接可以继续发送, 但这样会有时候遇到一些问题,无法获得后台的响应参数, 所以在你打开编辑弹出框完成数据编辑后无法刷新页面, 这时候可能存 ...
- 在发送ajax请求时加时间戳或者随机数去除js缓存
在发送ajax请求的时候,为了保证每次的都与服务器交互,就要传递一个参数每次都不一样,这里就用了时间戳 大家在系统开发中都可能会在js中用到ajax或者dwr,因为IE的缓存,使得我们在填入相同的值的 ...
- 原生js发送ajax请求
堕落了一阵子了,今天打开博客,发现连登录的用户名和密码都不记得了.2016年已过半,不能再这么晃荡下去了. 参加了网易微专业-前端攻城狮 培训,目前进行到大作业开发阶段,感觉举步维艰.但是无论如何,不 ...
- JQuery发送ajax请求不能用数组作为参数
JQuery发送ajax请求不能用数组作为参数,否则会接收不到参数, 一.js代码如下: $('#delete-button').click(function(){ var select ...
- ajax请求后台,返回json格式数据,模板!
添加一个用户的时候,需要找出公司下所有的部门,和相应部门下的角色,利用ajax请求,实现联动技术.将返回的json格式数据,添加到select标签下. <script type="te ...
随机推荐
- C Primer Plus(第五版)9
第 9 章 函数 在本章中你将学习下列内容: · 关键字: return (返回) · 运算符 * (一元) & (一元) · 函数及其定义方式. · 参数和返回值的使用方法. · 使用指针变 ...
- ListView设置setFooterDividersEnabled无效的原因
参考文章:http://gundumw100.iteye.com/blog/1169065 我的情况: 高度设置为了wrap_content, 且外边有一个FrameLayout(只包含了listvi ...
- 1、程序启动原理和UIApplication【转】
一.UIApplication 1.简单介绍 (1)UIApplication对象是应用程序的象征,一个UIApplication对象就代表一个应用程序. (2)每一个应用都有自己的UIApplica ...
- 稀疏矩阵乘法加法等的java实现
原创声明:本文系作者原创,转载请写明出处. 一.前言 前几天由于科研需要,一直在搞矩阵的稀疏表示的乘法,不过最近虽然把程序写出来了,还是无法处理大规模的矩阵(虽然已经是稀疏了).原因可能是 ...
- Flex4/Flash多文件上传(带进度条)实例分享
要求 必备知识 本文要求基本了解 Adobe Flex编程知识和JAVA基础知识. 开发环境 MyEclipse10/Flash Builder4.6/Flash Player11及以上 演示地址 演 ...
- Windows7下安装IIS出现“出现错误,并非所有的功能被成功更改
1.开始,搜索输入UAC-->选择 “更改用户账户控制设置” 2.调到最低 3.打开控制面板-->程序-->打开或关闭windows功能,去掉图里的2个选项,点确定,重启 4.重启后 ...
- AX2012全新的批处理方式
AX2009 的批处理操作我们是通过RunBaseBatch framework,我们所要做的事情就是继承RunBaseBatch class,实现里面该实现的方法来执行批处理. AX2012 的批处 ...
- oracle 将查询到的数据插入表
1. 新增一个表,通过另一个表的结构和数据 create table tab1 as select * from tab2 2. 如果表存在: insert into tab1 select * fr ...
- 【spring 4】AOP:动态代理
一.动态代理简介 动态代理与普通代理相比较,最大的好处是接口中声明的所有方法都被转移到一个集中的方法中处理(invoke),这样,在接口方法数量比较多的时候,我们可以进行灵活处理,而不需要像静态代理那 ...
- 织梦dedecms简略标题调用标签用法指南
我们在使用织梦DEDECMS建站过程中,为了使调用的文章标题简短且相对完整(原文标题太长),只好使用了调用简略标题这个方法,使标题显示为简短标题,指向标题时显示完整的标题.并获得文章静态地址链接 下面 ...