Jquery操作表格多出一个内容行
前言
我的前端实在是太差劲了,导致Jquery操作表格多出一个内容行,这个功能我都做不出来,我想着使用Bootstrap的折叠,还想着使用Jquery的显示消失,搞了半天没搞出来满意的效果。最后还是经理过来分分钟手写出来.....
我发现一个问题,所谓的.Net后端,Java后端,在互联网工作中基本都得会前端,至少会Jquery,Bootstrap这些,所以,我决定好好补习一下前端知识。
需求
需求就是标题了,我希望Jquery操作表格多出一个内容行,目前表格是这样的

我想点击其中的任意一行,点击之后这一行下面出来新的内容行,比如,我这一行点击之后去后台获取几行数据,然后展示出来
如何监听每一行点击,获取点击id
由于我想点击型号,就出来内容行,所以,我在型号上加一个内容,因为每一行都可以点击,所以我加id肯定是不行的,那只能加class了,而且,我每点击某一行,都得获取这一行的一个数据id,这个时候用id=变量id肯定是不行的,我怎么获取这个id的值呢?而且,我点击展开了,收缩的时候必须只收缩这行的,不能收缩全部的。所以结果如下
<tr id="mark@(item.ProductStockId)">
<td data-title="型号">
<span class="view-warehouse" data-id="@item.ProductStockId">
<i class="fa fa-plus-square-o"></i>
@item.ProductName
</span>
</td>
class写了,id我用data-id来代替了,这样我可以很方便的获取data-id的值。
重要的是我的tr标签写了一个id,叫mark,这是为了我的内容行以HTML的形式贴上去。mark后面加了id,这个是为了我收缩的时候,只收缩我这一行
前后端
我可以写一个js方法,
$(function () {
id=0;
innerHTML = "";
isGetMessage = false;
$("#example .view-warehouse").click(toggleWareHouse);
//$("#example .view-warehouse").hover(toggleWareHouse);
function toggleWareHouse(e) {
var $that = $(e.target);
var MessageId = $that.attr("data-id");
var icon = $that.find('i');
if (MessageId == id) {
isGetMessage = true
} else {
id = MessageId;
isGetMessage = false;
innerHTML = "";
}
if (!isGetMessage) {
isGetMessage = true;
$.ajax({
type: 'get',
url: '/ProductStock/GetProductWarehouse?ProductStockId=' + MessageId,
success: function (data) {
for (var i = 0; i < data.productStockWarehouses.length; i++) {
// style="display:none;"
innerHTML +=
'<tr class="ware' + MessageId + '"'+ '> <td colspan="5">库存详细信息</td>' +
'<td>' + data.productStockWarehouses[i].WarehouseId + '</td><td>数量' + data.productStockWarehouses[i].Quantity + '</td><td>有货</td>' +
'<td>' +
'<div class="btn-group">' +
'<button type="button" class="btn btn-default btn-sm">' +
'操作' +
'</button>' +
'<button type="button" class="btn btn-default btn-sm dropdown-toggle" data-toggle="dropdown">' +
'<span class="caret"></span>' +
'</button>' +
'<ul class="dropdown-menu" role="menu">' +
'<li>' +
'<a href="javascript:;"
'<i class="fa fa-edit"></i> 存货转仓' +
'</a>' +
'</li>' +
'<li>' +
'<a href="javascript:;">' +
'<i class="fa fa-trash-o"></i> 出库销售' +
'</a>' +
'</li>' +
'</ul>' +
'</div>' +
'</td></tr>';
}
$("#mark" + MessageId).after(innerHTML);
}
});
}
if (icon.hasClass('fa-plus-square-o')) {
icon.removeClass('fa-plus-square-o').addClass('fa-minus-square-o');
$(".ware" + MessageId).show();
$("#mark" + MessageId).after(innerHTML);
} else {
icon.removeClass('fa-minus-square-o').addClass('fa-plus-square-o');
$(".ware" + MessageId).hide();
$(".ware" + MessageId).html('');
}
}
});
这个是jquery的选择器,选择id为example 下的class为view-warehouse的元素进行监听,点击之后出发toggleWareHouse方法。
$("#example .view-warehouse").click(toggleWareHouse);
toggleWareHouse方法可以写一个e,这个e就是我们点击的内容,e.target就是我们点击的这一行元素
function toggleWareHouse(e) {
var $that = $(e.target);
下面这个就是找到i元素,然后切换图标
var icon = $that.find('i');
if (icon.hasClass('fa-plus-square-o')) {
icon.removeClass('fa-plus-square-o').addClass('fa-minus-square-o');
我们在每行的tr上加了一个mark标签,我们使用after方法,进行后面的html添加,这样添加的tr都是兄弟标签
$("#mark" + MessageId).after(innerHTML);
折叠的时候你的内容行是要删除的,这里使用html('');
$(".ware" + MessageId).html('');
然后到了内容行内容的时候了,其实可以选择在加载表格的时候直接把内容行全部加载出来隐藏着,分页一页才10个数据,所以不担心浪费资源。
我这里使用的是ajax去后台加载数据的方法,而且每次点击同一行只加载一次,我使用全局变量进行了判断
最后就是后端了,很简单
public ActionResult GetProductWarehouse(int ProductStockId)
{
List<ProductStockWarehouse> productStockWarehouses = _productStockWarehouseBll.GetProductStockWarehouseByProductStockId(ProductStockId);
return Json(new { productStockWarehouses },JsonRequestBehavior.AllowGet);
}
问题更新,ajax异步带来的问题
我发现一个问题,因为我是ajax请求的,而ajax请求默认是异步的,这导致了什么?
异步导致的问题是需要时间,而这个需要时间就出现了一个bug,我快速点击型号来加载内容行,我一秒点几次,会发现,会出现重复的内容行。
因为我在ajax异步消耗的时间中快速的重复点击,ajax异步还没反应过来呢,下面的js就执行了几次了。
修改这个问题就很简单了,把异步修改为同步,去掉ajax里面的innerHTML
ajax添加 async: false,
ajax内部删除 $("#mark" + MessageId).after(innerHTML);
废弃使用HTML拼接
| 注意:拼接HTML已经被淘汰,我以后不会这样做了 |
我的经理过来看了我写的代码,说HTML拼接已经废弃了,让我不要再使用。以后不使用了,直接在加载的时候把内容行加载进去然后隐藏吧
Jquery操作表格多出一个内容行的更多相关文章
- 超级简单的jquery操作表格(添加/删除行、添加/删除列)
利用jquery给指定的table添加一行.删除一行 <script language="javascript" src="./jquery.js"> ...
- jquery操作表格 合并单元格
jquery操作table,合并单元格,合并相同的行 合并的方法 $("#tableid").mergeCell({ cols:[X,X] ///参数为要合并的列}) /** * ...
- jQuery操作表格(table)的常用方法、技巧汇总
摘录自:http://www.jb51.net/article/48943.htm 虽然现在DIV+CSS进行页的布局大行其道,但是很多地方使用table还是有很多优势,用table展示数据是比较方便 ...
- 第七章 jQuery操作表格及其它应用
1.表格变色 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org ...
- JQUERY操作html--获取和设置内容、属性、回调函数
一:jQuery - 获取内容和属性 1.获得内容 - text().html() 以及 val() text() - 返回所选元素的文本内容 html() - 返回所选元素的内容(包括 HTML 标 ...
- jquery操作表格总结
返回表格行 或 列的索引 td是列,tr是行: <script type="text/javascript"> $(document).ready(function() ...
- 简单编程:如何用java来打印出一个5行的三角形
- jquery 操作表格实例
案例1:隔行变色,滑动,点击变色以(选中取消效果)(addClass(),removeClass(),toggleClass()) Html: <h4>1.隔行变行</h4> ...
- jquery实现表格复选框---多行选择问题(php变量)
1.html多选框标签行 表头的多选框,用于全选,取消全选 <th><input id='allSelected' type="checkbox">< ...
随机推荐
- fread/IO 模板
namespace Fread { char cb[1<<15],*cs,*ct; #define getc (cs==ct&&(ct=(cs=cb)+fread(cb,1 ...
- 初【001】——Python 基础知识
1.python基础入门 提示: 语法基于python3.x版本(会提示2.x版本和3.x版本的区别) Python命令行将以>>>开始,比如 >>>print ( ...
- 常用的两种web单点登录SSO的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...
- flutter报错:NoSuchMethodError: The method '>' was called on null.
写了个list,发现出不来,报错 flutter: Another exception was thrown: RenderBox was not laid out: _RenderScrollSem ...
- 使用pytesseract进行图像识别
引言 对于简单验证码及一些图像的识别,我们需要使用pytesseract及相应的Tesseract引擎,它是开源的OCR引擎.帮助我们做一些简单的图像识别 当然为了更好将图片识别,对一些像素比较低的图 ...
- AtCoder Grand Contest 019 题解
传送门 \(A\) 咕咕 int a,b,c,d,n,t; int main(){ scanf("%d%d%d%d%d",&a,&b,&c,&d,& ...
- (20)打鸡儿教你Vue.js
vue-cli 快速创建工程,工程化项目目录 npm uninstall -g vue-cli npm install -g @vue/cli https://www.bootcdn.cn/ http ...
- STP生成树算法
生成树算法第一:决定谁是“根网桥”对比各个网桥ID,先对比ID中的优先级,优先级相同的时候对比网桥MAC地址,对比依据是谁的值最小,谁是“根网桥” 第二:决定哪些是“根端口”窍门——每个非根网桥上都有 ...
- 蛋疼的springboot web项目使用jetty容器运行
出现的问题: 今天自己新建了一个maven webapp项目,准备自己看看springboot的东西,搭好的项目是这样的 一切都很正常啊,用run App的方式直接启动 成功啦,本应该到此结束,喝茶吃 ...
- 微信小程序实现左侧滑栏
前言 一直想给项目中的小程序设置侧滑栏,将退出按钮放到侧滑中,但是小程序没有提供相应的控件和API,因此只能自己手动实现,网上很多大神造的轮子很不错,本文就在是站在巨人的肩膀上实现. 效果 先看看效果 ...