本节内容主要介绍的是如何使用jQuery中的.html(),.text().val()三种方法,用于读取,修改元素的html结构,元素的文本内容,以及表单元素的value值的方法。jQuery中为我们提供了多种方法用于对元素的HTML结构和元素的文本内容的操作,比如说,你可以给已存在的元素的内部,周围,前面或者后面增加新元素;或者用一个元素替代另一个元素;你也可以读取或者修改一个元素的内容或结构。有时我们就会比较模糊,不知道是给元素增加内容或者增加一个元素,比如说我们需要给一个存在的元素有效的增加这个元素的内容。

这里主要和大家一起分享如何增加,删除和替换元素,jQuery给我们提供了三种方法来对元素的结构,内容进行操作:

  1. .html():读取和修改一个元素的HTML内容,详情.html()
  2. .text():读取和修改一个元素的文本内容,详情.text()
  3. .val():读取和修改一个表单元素的value字段值,详情.val()

正如你将看到的,这些方法可以让你轻松的读取或修改元素的原始内容或读取和修改任何HTML的值,也可以轻松的读取或修改表单中的value字段值。

操作元素的HTML结构——.html()

jQuery中的.html()方法可以让读取和修改一个元素的Html的内容,其主要有三种使用方式:.html(),.html(htmlString),.html(function(index,html){...}),下面依次来看看他们的具体使用方法。

1、读取一个元素的HTML结构——.html()

语法:

  1. $("Element").html();

返回值:string

说明:

.html()方法用来获取任意元素的HTML内容,如果选择器同时选中多于一个的元素时,那么其只能读取第一个元素的HTML内容。另外此法对XML方档是无效的。

要读取一个元素的HTML内容,首先你要选择这个元素,然后在调用jQuery中的.html()方法,比如说,下面的代码中,我们选择了div.demo中的p元素,然后通过.html()读取这个元素的HTML内容,如:

HTML Code:

  1. <div class="demo">
  2. <p>这是一个段落元素,里面包含了一个a链接元素<a href="#">W3CPLUS</a></p>
  3. </div>

jQuery Code

  1. $(document).ready(function(){
  2. alert("Div.demo中的p元素的HTML结构:"+$("div.demo p").html());
  3. });

结果

上面代码会弹出一个警告框,显示原始的HTML标记内的元素,如上图所示。上面是div.demo只有一个P元素,如果有多个呢?会有什么现像发生,我们不枋在看一回:

HTML Markup

  1. <div class="demo">
  2. <p>我是div.demo中第一个P元素:<a href="#">我在第一个P里面</a></p>
  3. <p>这是一个段落元素,里面包含了一个a链接元素<a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code

  1. $(document).ready(function(){
  2. alert("Div.demo中的p元素的HTML结构:"+$("div.demo p").html());
  3. });

效果

从上面效果图中我们可以明显的看出,同样的一段jQuery代码,所得到的效果不一样。这里再次证明了如果你调用多个选定元素的.html()方法,那么其读取的只是第一个元素,换句话说:如果选择器匹配多于一个的元素,那么只有第一个匹配元素的 HTML 内容会被获取。

2、修改一个元素的HTML内容——.html(htmlString)

语法:

  1. $("Element").html(htmlString);//htmlString是用来设置每个匹配元素的一个HTML 字符串

返回值:jQuery对象

说明:

重新设置第一个匹配元素的html内容,这些元素的任何内容完全被新的内容取代。基于上面的实例,将原来的段落的HTML内容完全取代:

HTML Markup

  1. <div class="demo">
  2. <p>我是div.demo中第一个P元素:<a href="#">我在第一个P里面</a></p>
  3. <p>这是一个段落元素,里面包含了一个a链接元素<a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code:

  1. $(document).ready(function(){
  2. $("div.demo p").html('<h2 class="title">新加的标题</h2><p>我是div.demo中第一个P元素:<a href="#">我在第一个P里面</a></p>');
  3. });

效果:

从上面的效果中我们得知:如果使用.html(htmlStrong)方法匹配在多个元素上,那么多个匹配元素将的HTML内容将被替换,并且都被替换成一样的HTML结构,也就是.html(htmlString)方法中指定的“htmlString”结构。换句话,如果你使用.html(htmlString)方法选定了多个元素,那么这些选定的元素的HTML内容都会被.html(htmlString)方法中的“htmlString”所替代。就如上图所示。

3。使用一个回调函数来替换一个元素的HTML内容

语法:

  1. $("Element").html(function(index,html){...});

返回值:jQuery对象

说明:

用来返回设置HTML内容的一个函数。接收元素的索引位置和元素旧的HTML作为参数。

使用个回调函数来替换一个元素的HTML内容,必须满足下面两个条件:

  1. 当前元素的索引值位置(index值从0开始计算);
  2. 当前元素的旧的html内容。

函数的返回值随后被用来作为替代HTML。这种做法很方便的,如果你要替换多个元素的内容,而且不想像上面那们换成相同的内容,而是换成不同的内容,那么我们就可以使用这种方法,根据元素自己的位置或现有的内容(或者两者同时)来给多个元素替换成不同的html内容。我们来看一个实例:

HTML Markup

  1. <div class="demo">
  2. <p><a href="#">我在第一个P里面</a></p>
  3. <p><a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code:

  1. $(document).ready(function(){
  2. $("div.demo p").html(function(index,oldHtml){
  3. return "我是段落" + (index+1) + ":" + oldHtml;
  4. });
  5. });

效果:

操作元素的纯文本内容——.text()

前面的.html()方法让你可以读取或修改元素的HTML内容——包括元素的HTML标签;而jQuery中的.text()方法仅仅是对元素的纯文本的操作。他和.html()方法一样包含了三种使用方法:

1、读取文本内容——.text()

语法:

  1. $("Element").text();

返回值:返回字符串;

说明:

将获取匹配元素集合中每个元素的文本内容结合,包括他们的后代。.text()和.html()方法不同,.text()方法都可以在XML和HTML文档中使用。.text()方法的结果是由所有匹配元素包含的文本内容组合起来的文本(由于不同的浏览器对HTML分析器的不同,在返回的文本换行和其他空格可能会有所不同。)

使用.text()和.html()方法都差不多相同,如:

HTML Markup

  1. <div class="demo">
  2. <p><a href="#">W3CPLUS</a></p>
  3. </div>

jQuery Code:

  1. $(document).ready(function(){
  2. alert(".text()读取的内容:" + $("div.demo p").text());
  3. });

效果:

从上面的效果中我们得知:使用.text()方法,我们只读取元素的纯文本内容,包括他的后代元素,而此元素中的HTML标签(包括其后代元素的HTML标签)都被剥离出去,只留下文本内容。

.text()和.html()方法一样可以同时选定多个元素,但有一点不同:.html()匹配多个元素时,只会读取匹配元素中的第一个;而.text()方法不同,他在匹配多个元素时,会同时读取多个元素的内容,如:

HTML Markup

  1. <div class="demo">
  2. <p><a href="#">W3CPLUS</a></p>
  3. <p>我是段落二:<a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code

  1. $(document).ready(function(){
  2. alert(".text()方法:" + $("div.demo p").text());
  3. alert(".html()方法:" + $("div.demo p").html());
  4. });

效果:

2、替换文本内容——.text(textString)

语法

  1. $("Element").text(textString);//textString用于设置匹配元素内容的文本

返回值:jQuery对象

说明:

.text(textString)方法和.html(htmlString)方法都是一样用来替换元素的内容,他们不同之种是:.html(htmlString)方法会把HTML标签当作新的HTML标签来替换原来的内容,而.text(textString)则把HTML标签会转换成纯文本内容来代替元素的旧内容。换句话说,.text(textString)方法中如果包含了HTML的标签,此方法会将< 替换为 &lt,>替换为&gt。 我们在前面的.html(htmlString)实例基础上把.html()换成.text()。

HTML Markup

  1. <div class="demo">
  2. <p><a href="#">W3CPLUS</a></p>
  3. <p>我是段落二:<a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code

  1. $(document).ready(function(){
  2. $("div.demo p").text('<h2 class="title">新加的标题</h2><p>我是div.demo中第一个P元素:< href="#">我在第一个P里面</a></p>');
  3. });

效果:

效果图上可以得知,.text(textString)方法会将HTML标签当作纯文本内容来替换元素的旧内容,这一点和.html(htmlString)方法是完全不一样,大家可以和前面的.html(htmlString)进行比较。不过他们有一个相同之处:如果匹配多个元素时,采用.text(textString)会将所匹配元素的内容替换成相同的内容。

3、使用一个回调函数来替换一个元素的文本内容

.text()方法和.html()方法一样,也要以通过一个回调函数来动态的替换多个元素的内容,不致于像.text(textString)把多个元素换成相同的内容。

语法

  1. $("Element").text(function(index,text){...});

返回值:jQuery对像

说明:

用来返回设置文本内容的一个函数。接收元素的索引位置和元素旧的文本值作为参数。使用回调函数来替换一个元素的内容,必须满足下面两个条件:

  1. 当前元素的索引值位置(index值从0开始计算);
  2. 当前元素的旧的文本内容。

函数的返回值随后被用来作为替代元素的纯文本内容。这种做法很方便的,如果你要替换多个元素的内容,而且不想像上面那们换成相同的内容,而是换成不同的内容,那么我们就可以使用这种方法,根据元素自己的位置或现有的内容(或者两者同时)来给多个元素替换成不同的千篇一文本内容。我们来看一个实例:

HTML Markup

  1. <div class="demo">
  2. <p><a href="#">我在第一个P里面</a></p>
  3. <p><a href="#">W3CPLUS</a></p>
  4. </div>

jQuery Code:

  1. $(document).ready(function(){
  2. $("div.demo p").text(function(index,oldText){
  3. return (index+1) + "." + oldText;
  4. });
  5. });

效果

操作表单字段Value值——.val()

前面介绍的.html()和.text()都无法在input元素上操作,那么我们接着看一个.val()方法。这个方法就像.text()方法一样,可以读取,修改表单字段“value”的值。

1、获取表单元素值——.val()

语法

  1. $("Element").val();

返回值:将返回的是字符串或数组

说明

.val()方法主要用于获取表单元素的值。至于“<select multiple="multiple">”元素,.val()方法返回一个包含每个选中的option的数组,对于下接选择框“<select>”和复选框,单选([type="checkbox"],[type="radio"])你可以使用“:selected”和“:checked”选择器来获取值。具体我们一来看几个实例:

HTML Markup

  1. <div id="colorRadio">
  2. <input type="radio" name="color" id="rd1" value="Red" />Red
  3. <input type="radio" name="color" id="rd2" value="Yello" />Yello
  4. <input type="radio" name="color" id="rd3" value="Blue" />Blue
  5. </div>
  6. <div id="sizeCheck">
  7. <input type="checkbox" name="size" id="ch1" value="10 pt" />10 pt
  8. <input type="checkbox" name="size" id="ch2" value="12 pt" />12 pt
  9. <input type="checkbox" name="size" id="ch3" value="14 pt" />14 pt
  10. </div>
  11. <input type="button" id="submitBtn" value="Get Value" />

jQuery Code

  1. $(document).ready(function () {
  2. $('#submitBtn').click(function () {
  3. alert($('#colorRadio input:radio').val());
  4. alert($('#sizeCheck input:checkbox').val());
  5. });
  6. });

效果

.val()返回的是匹配的元素集合中的第一个,有时你想返回选中的radio或checkbox的值,如果此时你只使用.val()方法,那么返回的将是第一个值,跟选中不选择中没有任何关系,就如上图所示,如果你想返回你选择的值,你就需要像下面这样操作,才能得到选中的值:

  1. $(document).ready(function () {
  2. $('#submitBtn').click(function () {
  3. alert($('input:radio[name=color]:checked').val());
  4. alert($('input:checkbox[name=size]:checked').val());
  5. });
  6. });

此时单选(radio)将返回你选择中的值,但checkbox不是,如果你同时选中多个checkbox时.val()只会返回第一个选择中的值,如果没有选中任何值,此时将返加的是“undefined”。刚才说过对于“checkbox”有多个选中时,返加的将只是第一个值,如果需要全部返回,我们就需要使用each()对checkbox进行遍历

  1. $(document).ready(function () {
  2. $('#submitBtn').click(function () {
  3. alert($('input:radio[name=color]:checked').val());
  4. $('input:checkbox[name=size]:checked').each( function() {
  5. alert( $(this).val());
  6. });
  7. });
  8. });

另外.val()在“select”时也分两种情况,当.val()方法应用在<select>元素上时,返回的是选中的值;另外一种情况是,当.val()方法应用在<select multiple="multiple">元素上时,返回的将是一个包含每个选中的 option 的数组。具体来看下面的一个例子。

HTML Markup

  1. <form action="" method="post">
  2. <select id="dropdown">
  3. <option>Red</option>
  4. <option>Yellow</option>
  5. <option>Blue</option>
  6. </select>
  7. <select id="listbox" multiple="multiple">
  8. <option>Red</option>
  9. <option>Yellow</option>
  10. <option>Blue</option>
  11. </select>
  12. <input type="button" id="getSelectValue" value="Get Value" />
  13. </form>

jQuery Code

  1. $("#getSelectValue").click(function(){
  2. alert($("#dropdown").val());
  3. var colors = $("#listbox").val();
  4. for(var key in colors){
  5. alert(colors[key]);
  6. }
  7. });

2、替换表单元素的Value值——.val(value)

语法

  1. $("Element").val(value);//value表示的是:一个文本字符串或一个以字符串形式的数组来设定每个匹配元素的值。

返回值jQuery对象

说明

这个方法常用来设置表单域的值,同样对于“<select multiple="multiple">”元素,多个option可以通过一个数组来选中。.val(value)可以同时改变选中元素的value值,而且其值是相同的,如:

  1. $("input").val("test");

上面代码最终会将所有inupt的value值替换成“test”,在平时的应用中我们一般是不这样使用的。.val(value)常应用在input[type="text"]的focus和blur上,如:

HTML Markup

  1. <input type="text" id="textBox" value="Hello,jQuery!" />

jQuery Code

  1. $("input:text").focus(function(){
  2. var $inputTextVal = $(this).val();
  3. if($inputTextVal == this.defaultValue) {
  4. $(this).val("");
  5. }
  6. });
  7. $("input:text").blur(function(){
  8. var $inputTextVal = $(this).val();
  9. if($inputTextVal == ""){
  10. $(this).val(this.defaultValue);
  11. }
  12. });

3、使用一个回调函数来替换表单字段“value”的值

前面的.val(value)可以将选中的表单元素的value值改成相同的,那么我们往往是需要设置成不同的value值,此时我们就需使用这个方法,通过一个函数来设置这个值。这个函数通过两个参数,当前元素的所引值和它当前的值。

语法

  1. $("Element").val(function(index,value){...});

返回值jQuery对象

说明

使用这个函数的返回值来设置每个匹配的input元素的“value”值,下面我们来看一个checkbox和radio上的实例:

HTML Markup

  1. <form action="">
  2. <div id="colorRadio">
  3. <input type="radio" name="color" id="rd1" value="Red" /><span id="color1">Red</span>
  4. <input type="radio" name="color" id="rd2" value="Yellow" /><span id="color2">Yellow</span>
  5. <input type="radio" name="color" id="rd3" value="Blue" /><span id="color3">Blue</span>
  6. </div>
  7. <div id="sizeCheck">
  8. <input type="checkbox" name="size" id="ch1" value="10 pt" /><span id="size1">10 pt</span>
  9. <input type="checkbox" name="size" id="ch2" value="12 pt " /><span id="size2">12 pt</span>
  10. <input type="checkbox" name="size" id="ch3" value="14 pt" /><span id="size3">14 pt</span>
  11. </div>
  12. <input type="text" id="txtBox" disabled="disabled" />
  13. <input type="button" id="setValue" value="Set Value" />
  14. </form>

jQuery Code

  1. $(document).ready(function(){
  2. $("input:radio[name=color]").val(function(index,oldVal){
  3. return "color-" + (index+1) + ":" + oldVal;
  4. });
  5.  
  6. $("input:checkbox[name=size]").val(function(index,oldVal){
  7. return "size-" + (index+1) + ":" + oldVal;
  8. });
  9. $("#setValue").click(function(){
  10. var $msg = $("input:radio[name=color]:checked").val() + ",";
  11. $("input:checkbox[name=size]:checked").each(function(){
  12. $msg += $(this).val() + ",";
  13. });
  14. $("#txtBox").val($msg);
  15. });
  16. });

对于多选择下接框,我们可以这样来改变:

HTML Markup

  1. <select id="dropdown">
  2. <option>Red</option>
  3. <option>Yellow</option>
  4. <option>Blue</option>
  5. </select>
  6. <select id="listbox" multiple="multiple">
  7. <option>Red</option>
  8. <option>Yellow</option>
  9. <option>Blue</option>
  10. </select>

jQuery Cody

  1. $(document).ready(function () {
  2. $('#dropdown').val('Yellow');
  3. $('#listbox').val(['Red', 'Blue']);
  4. });

上面介绍了.val()的具体使用方法,那么我们什么情况下可以使用.val()方法呢?

  1. 你可以使用.val()来读取和修改<select>选中的列表项。正如上面的实例所示,当然这些值已经在存在列表项中;
  2. 你可以使用.val()来读取<select multiple="multiple">选中的值,如果你选中多上选项值,此时.val()将返回的是一个option数组,不过你不能使用.val()给他设置多个值;
  3. 你可以使用.val()来读取radio和checkbox的值,也可以配合checked="checked"属性来读取选中的值,但对于checkbox需要使用each()进行遍历,否则只能读取第一个选中的值;
  4. 你可使用function动态改变表单中多个元素的value值。

这节主要学习了jQuery中的.html(),.text()和.val()三种方法的使用,最后总结一下这三个方法:

  1. .html()用为读取和修改元素的HTML标签
  2. .text()用来读取或修改元素的纯文本内容
  3. .val()用来读取或修改表单元素的value值。

这三个方法功能上的对比

  1. .html(),.text(),.val()三种方法都是用来读取选定元素的内容;只不过.html()是用来读取元素的HTML内容(包括其Html标签),.text()用来读取元素的纯文本内容,包括其后代元素,.val()是用来读取表单元素的"value"值。其中.和.text()方法不能使用在表单元素上,而.val()只能使用在表单元素上;另外.html()方法使用在多个元素上时,只读取第一个元素;.val()方法和.html()相同,如果其应用在多个元素上时,只能读取第一个表单元素的"value"值,但是.text()和他们不一样,如果.text()应用在多个元素上时,将会读取所有选中元素的文本内容。
  2. .html(htmlString),.text(textString)和.val(value)三种方法都是用来替换选中元素的内容,如果三个方法同时运用在多个元素上时,那么将会替换所有选中元素的内容。
  3. .html(),.text(),.val()都可以使用回调函数的返回值来动态的改变多个元素的内容。

如需转载烦请注明出处:W3CPLUS

jQuery学习笔记—— .html(),.text()和.val()的使用的更多相关文章

  1. 我的JQuery复习笔记之①——text(),html(),val()的区别

    text():①可匹配多个元素 ②过滤其中的标签(只显示文字) ③只适用于双标签 html():①只匹配选中元素中的第一个 ②不过滤其中标签 ③只适用于双标签 val():①只匹配选中元素中的第一个 ...

  2. jQuery 学习笔记

    jQuery 学习笔记   一.jQuery概述    宗旨: Write Less, Do More.    基础知识:        1.符号$代替document.getElementById( ...

  3. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

  4. jQuery学习笔记之Ajax用法详解

    这篇文章主要介绍了jQuery学习笔记之Ajax用法,结合实例形式较为详细的分析总结了jQuery中ajax的相关使用技巧,包括ajax请求.载入.处理.传递等,需要的朋友可以参考下 本文实例讲述了j ...

  5. jQuery学习笔记之DOM操作、事件绑定(2)

    jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...

  6. jQuery学习笔记之概念(1)

    jQuery学习笔记之概念(1) ----------------------学习目录-------------------- 1.概念 2.特点 3.选择器 4.DOM操作 5.事件 6.jQuer ...

  7. jQuery学习笔记(一)jQuery选择器

    目录 jQuery选择器的优点 基本选择器 层次选择器 过滤选择器 表单选择器 第一次写博客,希望自己能够长期坚持,以写博客的方式作为总结与复习. 最近一段时间开始学习jQuery,通过写一个jQue ...

  8. jQuery学习笔记(一):入门

      jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操 ...

  9. JQuery学习笔记——层级选择器

    JQuery学习笔记--层级选择器 上一篇学习了基础的五种选择,分别是id选择器,class选择器,element选择器,*选择器 和 并列选择器.根据手册大纲,这篇学习的是层级选择器. 选择器: 1 ...

随机推荐

  1. 发现在看完objc基本语法之后,还是看Apple文档比较有用。

    现在已经停止找中文资料了,因为很多例子已经过时,运行不出来. 看完objc基本语法以后,Apple的资料也看得懂了. 还是应该跟着Apple的入门指南开始学,今后也应该以Apple的文档为主.

  2. js实现td排序及分组分类

    如题 <!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o ...

  3. git 查看当前与上一次version的差异

    http://stackoverflow.com/questions/9903541/finding-diff-between-current-and-last-versions up vote47d ...

  4. 【多重背包模板】poj 1014

    #include <iostream> #include <stdio.h> #include <cstring> #define INF 100000000 us ...

  5. 关于cin.getline和cin.get

    <C++ Primer Plus(第六版)> P124 第8题 #include <iostream> using namespace std;   struct Pizza ...

  6. Newly Setting up a CentOS-7 system

    yum install -y epel-release glibc.i686 libtools vim clang git autoconf automake w3m glibc screen the ...

  7. Notes over compiling..

    When compiling VIM on windows, using nmake may be a better choice.. Because so far my attempts to co ...

  8. 简单hash[或者是哈希思想]

    题目链接 /* 有一个长度为n的只包含小写字母的字符串s,有m次操作,每次输入2个字符 A , B表示将s中的全部字符A变成B,B变成A. char sky[30],顺序记录每个字母的映射,在sky[ ...

  9. SSL交互过程

    SSL交互过程 HTTPS将HTTP和SSL结合,即加了SSL隧道封装的HTTP,通过SSL对客户端身份和服务器进行验证,对传输的数据进行加密.不同情况下SSL的协商过程存在差异,本节以只验证服务器为 ...

  10. AutoTile 自动拼接(六 大结局) 学习与实践

    昨天在网上找了一些资源图片,这回就不用担心 背景资源不多的问题了,现在我一边 制作,一边发布文章. 各种各样,500多个,这里还是特别感谢 ,万恶的资本主义,不设密码就给我分享. 在制作前,大家看下这 ...