jquery 配合 ajax 完成 在线编辑 你值得拥有

思路分析:
将 table中的表格 改变成为 input表格框获得值 ajax配合修改 删除
<?php
use yii\helpers\Url; $web = Url::base();
?>
<style>
.btn-save-data {
display: none;
} .btn-cancel-data {
display: none;
}
</style>
<script type="text/javascript"> //添加 页面 尾部追加 td input 框跟值
$("#onAddBaseDataCategory").click(function () { var trtd = $('<tr>' +
"<td class='code_one'><input name='code' type='text' value=''></td>" +
"<td class='name_one'><input name='name' type='text' value=''></td>" +
"<td class='tag_one'><input name='tag' type='text' value=''></td>" +
"<td class='table-text-align-left'>" +
"<a href=javascript:void(0) onclick='onSaveBaseDataCategory(this)' data-id= '' class='btn btn-link'>保存</a>" +
"<a href=javascript:void(0) onclick='cancelBaseDataCategory(this)' data-id= '' class='btn btn-link'>取消</a>" +
"</td>" +
"</tr>");
trtd.prependTo("#baseDataCategoryTable"); }); //编辑页面
function onEditData(obj) { var id = $(obj).attr('data-id');
var object = $(obj).parent().parent(); object.find('.btn-edit-data').hide();
object.find('.btn-delete-data').hide();
object.find('.btn-save-data').show();
object.find('.btn-cancel-data').show(); var code = object.find(".code_one").text();
var name = object.find(".name_one").text();
var tag = object.find(".tag_one").text(); object.find(".code_one").html("<input data-base-title='" + code + "' name='code' type='text' value='" + code + "'>");
object.find(".name_one").html("<input data-base-title='" + name + "' name='name' type='text' value='" + name + "'>");
object.find(".tag_one").html("<input data-base-title='" + tag + "' name='tag' type='text' value='" + tag + "'>"); } // 数据保存
function onSaveBaseDataCategory(obj) { var object = $(obj).parent().parent();
object.find('.btn-save-data').show();
var id = $(obj).attr('data-id');
var is_enabled = 1; var data = {};
var code = object.find('input[name="code"]').val();
var name = object.find('input[name="name"]').val();
var tag = object.find('input[name="tag"]').val(); if (id == '') {
id = null;
} data.code = code;
data.name = name;
data.tag = tag;
data.is_enabled = is_enabled;
data.id = id; requestJson("base-data-category-save-handler", data, true, function (response) {
if (response.status == 0) {
id = response.data.id; //ajax 添加|修改 成功后 读取数据库的id
replace(object, id, code, name, tag);
} else {
errorDialog(response.message);
}
}); } //取消
function cancelBaseDataCategory(obj) { var object = $(obj).parent().parent();
var id = $(obj).attr('data-id'); if (id == '') {
object.remove();
return;
} var code = object.find('input[name="code"]').attr('data-base-title');
var name = object.find('input[name="name"]').attr('data-base-title');
var tag = object.find('input[name="tag"]').attr('data-base-title'); // //替换
object.find('.code_one').html("<td class='code_one'>" + code + "</td>");
object.find('.name_one').html("<td class='name_one'>" + name + "</td>");
object.find('.tag_one').html("<td class='tag_one'>" + tag + "</td>"); object.find('.btn-edit-data').show();
object.find('.btn-delete-data').show();
object.find('.btn-save-data').hide();
object.find('.btn-cancel-data').hide();
} //input 框 替换 表格
function replace(object, id, code, name, tag) {
var tr = '<tr>' +
"<td class='code_one'>" + code + "</td>" +
"<td class='name_one'>" + name + "</td>" +
"<td class='tag_one'>" + tag + "</td>" +
"<td class='table-text-align-left'>" +
"<a href=javascript:void(0) onclick='onEditData(this)' data-id='" + id + "' " +
"class='btn btn-link btn-edit-data'>编辑</a>" + "<a href=javascript:void(0) onclick='deleteBaseDataCategory(this)' data-id='" + id + "'" +
"class='btn btn-link btn-delete-data'>删除</a>" + "<a href=javascript:void(0) onclick='onSaveBaseDataCategory(this)' data-id='" + id + "'" +
"class='btn btn-link btn-save-data'>保存</a>" + "<a href=javascript:void(0) onclick='cancelBaseDataCategory(this)' data-id='" + id + "'" +
" class='btn btn-link btn-cancel-data'>取消</a>" +
"</td>" +
"</tr>";
object.replaceWith(tr);
return true;
} //删除基础分类
function deleteBaseDataCategory(obj) {
var object = $(obj).parent().parent();
var id = $(obj).attr('data-id');var data = {};
data.id = id;
requestJson('base-data-category-delete-handler', data, true, function (response) {
if (response.status == 0) {
object.remove();
} else {
errorDialog(response.message); //这是错误提示 自己封装的
}
}) } </script>
<div class="form-horizontal" id="base_data_category_submit_form">
<div class="panel panel-frame panel-operat">
<div class="panel-body">
<div class="panel-content">
<a type="button" class="btn btn-primary putaway-icon ">
<div class="btn-icon"></div>
<div id="onAddBaseDataCategory" class="btn-text">添加</div>
</a>
</div>
</div>
</div> <div class="panel panel-frame">
<div class="table-responsive">
<table class="table table-bordered table-hover" id="baseDataCategoryTable">
<thead>
<tr id="th">
<th>编码</th>
<th>名称</th>
<th>标签</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<?php
foreach ($items as $item) {
?>
<tr>
<td class='code_one'><?= $item['code'] ?></td>
<td class='name_one'><?= $item['name'] ?></td>
<td class='tag_one'><?= $item['tag'] ?></td>
<td class='table-text-align-left'>
<a href="javascript:void(0);" onclick="onEditData(this)" data-id="<?= $item['id'] ?>"
class='btn btn-link btn-edit-data'>编辑</a>
<a href="javascript:void(0);" onclick="deleteBaseDataCategory(this)"
data-id="<?= $item['id'] ?>"
class='btn btn-link btn-delete-data'>删除</a>
<a href="javascript:void(0);" onclick="onSaveBaseDataCategory(this)"
data-id="<?= $item['id'] ?>"
class='btn btn-link btn-save-data'>保存</a>
<a href=javascript:void(0) onclick='cancelBaseDataCategory(this)'
data-id="<?= $item['id'] ?>"
class='btn btn-link btn-cancel-data'>取消</a>
</td>
</tr>
<?php
}
?>
</tbody>
</table>
</div>
<div class="table-pagination">
</div>
</div>
</div>
ps: requestJson 是我自己封装的ajax请求 : 配合 yii框架使用的 我给大家分享一下
/**
* ajax获取json数据
* @param url
* @param data
* @param async
* @param successFun
* @param errorFun
* @returns {{}}
*/
requestJson = function (url, data, async, successFun, errorFun) {
if (!(typeof loading === 'undefined')) {
loading.show();
} var responseData = {};
responseData.status = -100;
responseData.message = '网络不给力!';
responseData.data = null; // data._csrf = $('meta[name="csrf-token"]').attr("content"); $.ajax({
async: async || false,
type: "POST",
url: url,
data: data,
dataType: "json",
success: function (data) {
responseData = data; if (successFun) {
successFun(data);
} if (!(typeof loading === 'undefined')) {
loading.hide();
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
if (!(typeof loading === 'undefined')) {
loading.hide();
} responseData.status = -101;
responseData.message = XMLHttpRequest.responseText; // errorMessage(responseData.message); if (errorFun) {
errorFun(responseData);
}
}
}); return responseData;
};
jquery 配合 ajax 完成 在线编辑 你值得拥有的更多相关文章
- [前端插件]Bootstrap Table服务器分页与在线编辑应用总结
先看Bootstrap Table应用效果: 表格用来显示数据库中的数据,数据通过AJAX从服务器加载,同时分页功能有服务器实现,避免客户端分页,在加载大量数据时造成的用户体验不好.还可以设置查询数据 ...
- python 全栈开发,Day56(jQuery的ajax)
昨日内容回顾 事件流: 1.事件捕获 从最外层到最内层 2.事件目标阶段 3.事件冒泡 从最内层到最外层 每个事件都会事件对象 event 属性和方法 属性: event.target 目标节点(冒泡 ...
- 补充:jQuery的ajax
一.jQuery的ajax 什么是ajax AJAX = 异步的javascript和XML(Asynchronous Javascript and XML) 简言之,在不重载整个网页的情况下,AJA ...
- 【原创经验分享】JQuery(Ajax)调用WCF服务
最近在学习这个WCF,由于刚开始学 不久,发现网上的一些WCF教程都比较简单,感觉功能跟WebService没什么特别大的区别,但是看网上的介绍,就说WCF比WebService牛逼多少多少,反正我刚 ...
- jQuery与ajax 基础运用
jQuery是一个轻量级js框架,使用方便快捷,更是封装ajax处理方法,如$.load() $.get() $.post() 等 但最常用的方法还是$.ajax() 一.一般的格式为 $.ajax( ...
- 关于Jquery中ajax介绍
jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $.post 等.$.ajax() 返回其创建的 XMLHttpRequest 对象.大多数情况下你无需直接操作该函数,除非你需 ...
- 网页实时聊天之js和jQuery实现ajax长轮询
众所周知,HTTP协议是无状态的,所以一次的请求都是一个单独的事件,和前后都没有联系.所以我们在解决网页实时聊天时就遇到一个问题,如何保证与服务器的长时间联系,从而源源不段地获取信息. 一直以来的方式 ...
- 触碰jQuery:AJAX异步详解
触碰jQuery:AJAX异步详解 传送门:异步编程系列目录…… 示例源码:触碰jQuery:AJAX异步详解.rar AJAX 全称 Asynchronous JavaScript and XML( ...
- jQuery调用AJAX异步详解[转]
AJAX 全称 Asynchronous JavaScript and XML(异步的 JavaScript 和 XML).它并非一种新的技术,而是以下几种原有技术的结合体. 1) 使用CSS和X ...
随机推荐
- hibernate课程 初探一对多映射2-6 测试-添加和查询学生信息
package com.ddwei.entity; import java.util.Set; import org.hibernate.Session; import org.hibernate.T ...
- 粗看ES6之字符串
标签: javascript es6 字符串新增特性 新增二个方法 - startsWith/endsWith 字符串模板 - 反单引号的应用 startsWith 判断字符串以是否以某某开头,返回一 ...
- Redis入门--(一)简介NoSQL
1.什么是NoSql? 2.为什么需要NoSQL? 互联网经历了1.0和2.0的发展: web1.0 是早期新浪,雅虎等只能浏览,不能交互: 传统关系型数据库在应付web2.0这种动态网站的时候力不从 ...
- 从零开始的全栈工程师——js篇(闭包)
闭包是js中的一大特色,也是一大难点.简单来说,所谓闭包就是说,一个函数能够访问其函数外部作用域中的变量. 闭包的三大特点为: 1.函数嵌套函数 2.内部函数可以访问外部函数的变量 3.参数和变量不会 ...
- 1像素border
1像素border 利用伪类和媒体查询: 伪类: border-1px($color) position:relative &:after display: block position: a ...
- C++ Knowledge series 5
Programming language evolves always along with Compiler's evolvement On the Cusp of the Object Model ...
- Android studio 安装与配置【Android学习入门】
终于下定决心认真学习Android开发了. 之前在很多平台看到很多大牛们学习Android的经验和心得,纸上得来终觉浅. 这里推荐stormzhang老师总结的Android学习之路. 为了防止电脑卡 ...
- gradle方式集成融云sdk dlopen failed: library "libsqlite.so" not found
1.gradle implementation 'cn.rongcloud.android:IMLib:2.8.6' implementation 'cn.rongcloud.android:IMKi ...
- php的yii框架开发总结3
利用yii里面的gii工具可以很容易的自动创建数据表相应的的CURD操作的基于MVC的文件: 首先,打开:自己网站/protected/config/main.php文件 'modules'=> ...
- Linux命令之查看日志等实时文件命令(less 、tail)使用
一.less的使用 1)less 文件名,即可快速打开文件 2)相关查看搜索 3)利用键盘向上向下箭头键盘上的向上和向下箭头,点击一次向下简单,文件内容往下读取一行:点击一次向上箭头,文件内容,往上 ...