文档章节

Java Web(7) jQuery 使用问题集

Jagery
 Jagery
发布于 2015/11/23 12:54
字数 1230
阅读 41
收藏 0

1. 项目中,进行分页查看的时候,打算使用struts标签iterator来遍历输出数据,并在遍历中比较其当前页来为当前页的链接添加class="active"样式来着色显示。

<s:iterator value="listPage" var="index" >
    <s:if text="index != currentPage">
    <li>
	<a href='<s:url action="admin-depart"><s:param name="currentPage" value="index"/></s:url>'>
	${index} 
    	</a>
    </li>
    </s:if>
    <s:elseif>
    <li class="currentPage">
	<a href='<s:url action="admin-depart"><s:param name="currentPage" value="index"/></s:url>'>
	${index} 
    	</a>
    </li>
    </s:elseif>
</s:iterator>

其中listPage是List<Integer> currentPage是int ,两个都是action里的栈值。

但是结果都是不相等的情况,没办法,只能在使用js来控制了

2. 首先把jsp的代码改了一下

<ul id="pageInation">
<s:iterator value="listPage" var="index" >   
    <li>
	<a href='<s:url action="admin-depart"><s:param name="currentPage" value="index"/></s:url>'>
	${index} 
    	</a>
    </li>    
</s:iterator>
</ul>

3. 现在问题来了,我该怎么在ul里遍历li并获取到a的文本来与currentPage来比较,然后为其添加class呢。

    在jQuery有一个children,还有一个filter。代码如下

<script type="text/javascript">		
(function($){
    $('#pageInation').children('li')
    .filter(
    function(index){
	var str = $('a',this).text().trim();
	return str == ${currentPage};
    }			
    ).addClass("active") ;
})(jQuery);
</script>

    首先通过id选择器来获取到ul节点,然后再使用children来选择到ul下的子节点li。

    关键的地方来了,使用filter来过滤掉不符合的li。

    在filter中,可以直接使用选择器来,也可以传入function参数,我就是把一个function函数传入进去 ,只要filter返回的是true,接下来的addClass就会执行。

    而${currentPage}是struts2 的OGNL表达式,获取currentPage。

    这一堆代码是放在一个立即执行的js匿名函数中,其结构如下   

(function(a){
    //do somthing
})(a);

    

4. 举个例子,比如在向页面新添加一个<p>,并对其进行click事件监听,使它在鼠标点击后隐藏。

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $("p").click(function(){
    $(this).slideToggle();
  });
  $("button").click(function(){
    $("<p>This is a new paragraph.</p>").insertAfter("button");
  });
});
</script>
</head>
<body>
<p>这是一个段落。</p>
<p>点击任意 p 元素会令其消失。包括本段落。</p>
<button>在本按钮后面插入新的 p 元素</button>
<p><b>注释:</b>通过使用 live() 方法而不是 bind() 方法,新的 p 元素同样会在点击时消失。</p>
</body>
</html>

    但是在运行后,却发现是没有反应的。我想,这是因为click方法监听的只是原有页面载的节点点击事件,比如把上面改成这样

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $("p").click(function(){
    $(this).slideToggle();
  });  
});
</script>
</head>
<body>
<p>这是一个段落。</p>
<p>点击任意 p 元素会令其消失。包括本段落。</p>
<p><b>注释:</b>通过使用 live() 方法而不是 bind() 方法,新的 p 元素同样会在点击时消失。</p>
</body>
</html>

    可以看到,事件监听是有反应的。那问题来了,我们如何对未来新添加的DOM节点进行事件监听呢

    答案是 在jquery-1.7——1.9之间使用live,之后的就要使用on来对其未来新节点监听,因为在jquery-1.9 之后就把live 移除掉了,再次使用会报错无法运行js代码的。

    但是,改成这样子后,发现还是出现了点问题,新节点点击监听还是没有反应   

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $("p").on("click",function(){
    $(this).slideToggle();
  });
  $("button").click(function(){
    $("<p>This is a new paragraph.</p>").insertAfter("button");
  });
});
</script>
</head>
<body>
<p>这是一个段落。</p>
<p>点击任意 p 元素会令其消失。包括本段落。</p>
<button>在本按钮后面插入新的 p 元素</button>
<p><b>注释:</b>通过使用 live() 方法而不是 bind() 方法,新的 p 元素同样会在点击时消失。</p>
</body>
</html>

    思考无果,无奈度娘,找到了网友fhq198604 的百度知道答案jquery on()绑定的点击事件在js动态新添加的元素上无效,请问为什么

    答案中,解释是因为,我们在对新添加的节点监听事件的时候,其选择器应该是要选择document,即应该使用$(document)来对其节点选择,修改如下   

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
    <!-- 修改的地方 -->
  $(document).on("click","p",function(){
    $(this).slideToggle();
  });
  $("button").click(function(){
    $("<p>This is a new paragraph.</p>").insertAfter("button");
  });
});
</script>
</head>
<body>
<p>这是一个段落。</p>
<p>点击任意 p 元素会令其消失。包括本段落。</p>
<button>在本按钮后面插入新的 p 元素</button>
<p><b>注释:</b>通过使用 live() 方法而不是 bind() 方法,新的 p 元素同样会在点击时消失。</p>
</body>
</html>

5. 在这里贴上官方解释jQuery on()


© 著作权归作者所有

共有 人打赏支持
Jagery
粉丝 3
博文 23
码字总数 11583
作品 0
玉林
程序员
使用java的html解析器jsoup和jQuery实现一个自动重复抓取任意网站页面指定元素的...

日期:2012-7-20 来源:GBin1.com 在线演示 本地下载 如果你曾经开发过内容聚合类网站的话,使用程序动态整合来自不同页面或者网站内容的功能肯定对于你来说非常熟悉。通常使用java的话,我们...

gbin1
2012/07/20
0
0
JQuery 和 Extjs 比较

JQuery 和 Extjs 比较 一、JQuery 和 Extjs 比较 JQuery-EasyUI是仿照Ext做的。 Ext框架是一个整体,面向对象的编程思想,每个控件之间可以相互通讯。JQuery的控件全都是分散的,没有整体性可...

Amamatthew
2014/09/11
0
0
Android WebView 与JS的数据交互

关于WebView 我们知道目前android市场上的一些应用采用的开发方式大致分为三种:Native App、Web App、Hybrid App。本文主要是Hybrid App中实现的主要技术native组件与js的数据交互的理解以及...

习惯_搬砖
2015/05/06
0
0
jQuery学习笔记之JavaScript脚本库和元素选择器研究[图]

jQuery学习笔记之JavaScript脚本库和元素选择器研究[图] jQuery是一套JavaScript脚本库,相当于Java的类库,将一些工具方法或者对象方法封装在类库中,方便用户使用。 工厂函数指的是这些内建...

原创小博客
08/06
0
0
简单灵活的 Java CMS - EasyCms

简介 Java EasyCms 使用最简单性能最高的框架,将cms系统简单到极致,灵活的栏目扩展,快速的构建普通网站 生成的静态演示站(测试): www.j4cms.com 用到的框架工具 java,servlet,guice...

姜小北
2017/08/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

day99-20180926-英语流利阅读-待学习

换汤不换药的美容大忽悠:从抗衰老到肌肤焕发新生 Lala 2018-09-26 1.今日导读 说到护肤品,一个个大牌广告就浮现在我们眼前:皮肤吹弹可破的女明星手捧功能各异的瓶瓶罐罐,暗示着消费者买买...

飞鱼说编程
36分钟前
3
0
FFmpeg Maintainer赵军:FFmpeg关键组件与硬件加速

大家好!我是赵军,现就职于英特尔的DCG从事基于FFmpeg的硬件优化工作,两年多前加入FFmpeg社区,2018年4月成为FFmpeg的其中的一个FFmpeg Maintainer,主要负责FFmpeg的硬件优化工作。 概览:...

yizhichao
今天
1
0
ehlib 修改 使行号字体颜色 与标题字体颜色 一致

对ehlib 显示效果不够满意,而做的调整 修改这个过程:procedure TCustomDBGridEh.DrawIndicatorCell(ACol, ARow: Longint; AreaCol, AreaRow: Longint; ARect: TRect; AState: TGri......

vga
今天
1
0
Bash重定向详解

Bash重定向详解 Bash的重定向指的是将命令的输入和输出导向不同地方,而不是默认的标准输入、标准输出和标准错误。Bash的重定向实际上是对标准输入、标准输出和标准错误的重置,进而将所需输...

小陶小陶
今天
3
0
EventBus原理深度解析

一、问题描述 在工作中,经常会遇见使用异步的方式来发送事件,或者触发另外一个动作:经常用到的框架是MQ(分布式方式通知)。如果是同一个jvm里面通知的话,就可以使用EventBus。由于Event...

yangjianzhou
今天
59
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部