深入学习jQuery描述文本内容的3个方法
前面的话
在javascript中,描述元素内容有5个属性,分别是innerHTML、outerHTML、innerText、outerText和textContent。这5个属性各自有各自的功能,且兼容性不同。jQuery针对这样的处理提供了3个便捷的方法,分别是:html()、text()和val()。本文将详细介绍jQuery描述文本内容的这3个方法
html()
html()方法类似于javascript中的innerHTML属性,用来获取集合中第一个匹配元素的HTML内容或设置每一个匹配元素的html内容,具体有3种用法:
【1】html()
html()不传入值可以用来获取集合中第一个匹配元素的HTML内容
[注意]与innerHTML属性的问题相同,IE8-浏览器会将所有标签转换成大写形式,且不包含空白文本节点;而其他浏览器则原样返回
- <div class="test">
- <div>Demonstration Box</div>
- </div>
- <div class="test">
- <div>123</div>
- </div>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- //' <div>Demonstration Box</div>'
- console.log($('.test').html());
- </script>
【2】html(htmlString)
html(htmlString)方法设置每一个匹配元素的html内容,这些元素中的任何内容会完全被新的内容取代。此外,用新的内容替换这些元素前,jQuery从子元素删除其他结构,如数据和事件处理程序,这样可以防止内存溢出
- <div class="demo-container">
- <div class="demo-box">Demonstration Box</div>
- </div>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- //123
- $('div.demo-container').html('123');
- </script>
【3】html(function(index, oldhtml))
html(function(index, oldhtml))用来返回设置HTML内容的一个函数。接收元素的索引位置和元素原先的HTML作为参数。jQuery的调用这个函数之前会清空元素,使用oldhtml参数引用先前的内容。在这个函数中,this指向元素集合中的当前元素
- <div class="demo-container">123</div>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- //1230
- $('div.demo-container').html(function(index,oldhtml) {
- return oldhtml + index;
- });
- </script>
使用范围
与innerHTML属性相同,html()方法只能应用于双标签,单标签无效
- <input id="test" value="123">
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- console.log(test.innerHTML)//''
- console.log($('#test').html())//''
- </script>
text()
text()方法类似于javascript中的innerText属性,得到匹配元素集合中每个元素的文本内容结合,包括他们的后代,或设置匹配元素集合中每个元素的文本内容为指定的文本内容,具体有3种用法:
【1】text()
text()方法得到匹配元素集合中每个元素的合并文本,包括他们的后代
- <p id="test">This is a <i>simple</i> document</p>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- //This is a simple document
- console.log($('#test').text());
- </script>
- <div>1</div>
- <div>2</div>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- //12
- console.log($('div').text());
- </script>
【2】text(textString)
text(textString)用来设置匹配元素集合中每个元素的文本内容为指定的文本内容
- <p id="test">This is a <i>simple</i> document</p>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- $('#test').text('<i>123</i>');
- //'<i>123</i>'
- console.log($('#test').text());
- </script>
【3】text(function(index, text))
text(function(index, text))方法通过使用一个函数来设置文本内容,该函数接收元素的索引位置和文本值作为参数,返回设置的文本内容
- <p id="test">This is a <i>simple</i> document</p>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- $('#test').text(function(index, text){
- return text + index;
- });
- //'This is a simple document0'
- console.log($('#test').text());
- </script>
该方法常用于数据初始化,使用html()方法也可以实现同样效果
- <ul>
- <li></li>
- <li></li>
- <li></li>
- </ul>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- $('ul li').text(function(index, text){
- return '内容' + (index+1);
- });
- //'内容1内容2内容3'
- console.log($('li').text());
- //'内容1'
- console.log($('li').html());
- </script>
使用范围
与innerText属性相同,text()方法不能使用在input元素。在IE8-浏览器下,text()方法不能使用在script元素上
input元素可以使用val()方法获取或设置文本值;script元素可以使用html()方法
- <input id="test1" value="123">
- <script id="test2">
- var a = 1;
- </script>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- console.log($('#test1').text());//''
- //IE8-浏览器返回'',其他浏览器返回'var a = 1;'
- console.log($('#test2').text());
- console.log($('#test1').val());//'123'
- console.log($('#test2').html());//'var a = 1;'
- </script>
val()
val()方法类似于javascript中的value属性,主要是用于处理表单元素的值,用于获取匹配的元素集合中第一个元素的当前值或设置匹配的元素集合中每个元素的值
val()
当val()方法没有参数时,表示获取元素的value值
- <input id="test" value="text">
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- console.log($('#test').val());//'text'
- </script>
[注意]通过val()方法从textarea元素中取得的值是不含有回车(\r)字符的。但是如果该值是通过XHR传递给服务器的,回车(\r)字符会被保留(或者是被浏览器添加的,但是在原始数据中并不包含回车(\r))。可以使用下面的valHook方法解决这个问题
- $.valHooks.textarea = {
- get: function(elem){
- return elem.value.replace(/\r?\n/g,"\r\n");
- }
- };
val()方法主要用于获取表单元素的值,比如input,select和textarea。对 <select multiple="multiple">元素,val()方法返回一个包含每个选择项的数组,如果没有选择性被选中,它返回null
- <textarea id="test1">1</textarea>
- <input id="test2" value="2">
- <select id="test3">
- <option>3</option>
- </select>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- console.log($('#test1').val());//1
- console.log($('#test2').val());//2
- console.log($('#test3').val());//3
- </script>
val(value)
val(value)用来设置表单元素的value值
- <input id="test" value="2">
- <button id="btn">按钮</button>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- btn.onclick = function(){
- var value = $('#test').val();
- $('#test').val('测试'+ value)
- }
- </script>
val(function(index, value))
val()方法可以接受一个函数作为参数,函数中的this指向当前元素。接收的集合中的元素,旧的值作为参数的索引位置,返回设置的值
- <input id="test" value="2">
- <button id="btn">按钮</button>
- <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
- <script>
- btn.onclick = function(){
- $('#test').val(function(index,value){
- return '测试'+index + value;
- })
- }
- </script>
总结
html()、text()、val()三种方法都是用来读取选定元素的内容;html()是用来读取元素的html内容,text()用来读取元素的纯文本内容,val()是用来读取表单元素的value值。其中html()和text()方法不能使用在表单元素上,而val()只能使用在表单元素上
html()和val()方法使用在多个元素上时,只读取第一个元素;而text()方法应用在多个元素上时,将会读取所有选中元素的文本内容
html(htmlString)、text(textString)和val(value)三种方法都是用来替换选中元素的内容,如果三个方法同时运用在多个元素上时,那么将会替换所有选中元素的内容
html()、text()、val()都可以使用回调函数的返回值来动态改变多个元素的内容
深入学习jQuery描述文本内容的3个方法的更多相关文章
- Jquery操作文本内容(三个方法:html()、text()、var())
Jquery操作文本内容(三个方法:html().text().var()) 一.html()获取和设置文本内容和标签 1.获取标签里的结构和内容 $("ul").html() / ...
- 如何遍历div里面的文本内容,用each方法,
如何遍历div里面的文本内容,然后进行匹配传来的数据,进行选中div,并进行CSS样式处理, for(i = 0; i< $(".itemMenuRowBox").child ...
- jquery 替换文本内容
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...
- iOS学习之根据文本内容动态计算文本框高度的步骤
在视图加载的过程中,是先计算出frame,再根据frame加载视图的,所以在设计计算高度的方法的时候,设计成加号方法; //首先给外界提供计算cell高度的方法 + (CGFloat)heightFo ...
- Android应用开发EditText文本内容变化监听方法
import android.app.Activity; import android.os.Bundle; import android.text.Editable; import android. ...
- Android EditText文本内容变化监听方法
package com.google; import android.app.Activity; import android.os.Bundle; import android.text.Edita ...
- js/jquery获取文本框的值与改变文本框的值
我们就用它来学习获取文本框的值及改变文本框的值. 代码如下 复制代码 <script>function get1(){ document.getElementById("txtb ...
- Jquery实现textarea根据文本内容自适应高度
本文给大家分享的是Jquery实现textarea根据文本内容自适应高度,这些在平时的项目中挺实用的,所以抽空封装了一个文本框根据输入内容自适应高度的插件,这里推荐给小伙伴们. autoTextare ...
- jquery获取文本框的内容
使用jquery获取文本框的内容有以下几种: 1.根据ID取值(id属性): // javascript <script type="text/javascript"> ...
随机推荐
- Android raw to bmp
Android raw 格式转 bmp 图像 raw 保存的为裸数据,转换时都需要把它转成RGBA 的方式来显示.其中: 8位RAW: 四位RGBA 来表示一位灰度; 24位RAW: 三位RGB相同, ...
- ASP.NET Core应用中如何记录和查看日志
日志记录不仅对于我们开发的应用,还是对于ASP.NET Core框架功能都是一项非常重要的功能特性.我们知道ASP.NET Core使用的是一个极具扩展性的日志系统,该系统由Logger.Logger ...
- Python应用03 使用PyQT制作视频播放器
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载. 最近研究了Python的两个GUI包,Tkinter和PyQT.这两个GUI包的底层分别是Tcl/ ...
- jquery.Callbacks的实现
前言 本人是一个热爱前端的菜鸟,一直喜欢学习js原生,对于jq这种js库,比较喜欢理解他的实现,虽然自己能力有限,水平很低,但是勉勉强强也算是能够懂一点吧,对于jq源码解读系列,博客园里有很多,推荐大 ...
- 微框架spark--api开发利器
spark简介 Spark(注意不要同Apache Spark混淆)的设计初衷是,可以简单容易地创建REST API或Web应用程序.它是一个灵活.简洁的框架,大小只有1MB.Spark允许用户自己选 ...
- Velocity初探小结--velocity使用语法详解
做java开发的朋友一般对JSP是比较熟悉的,大部分人第一次学习开发View层都是使用JSP来进行页面渲染的,我们都知道JSP是可以嵌入java代码的,在远古时代,java程序员甚至在一个jsp页面上 ...
- WPF CheckBox 样式
<Style x:Key="FocusVisual"> <Setter Property="Control.Template"> < ...
- ES6(块级作用域)
我们都知道在javascript里是没有块级作用域的,而ES6添加了块级作用域,块级作用域能带来什么好处呢?为什么会添加这个功能呢?那就得了解ES5没有块级作用域时出现了哪些问题. ES5在没有块级作 ...
- github免输用户名/密码SSH登录的配置
从github上获取的,自己整理了下,以备后用. Generating an SSH key mac windows SSH keys are a way to identify trusted co ...
- 二次剩余、三次剩余、k次剩余
今天研究了一下这块内容...首先是板子 #include <iostream> #include <stdio.h> #include <math.h> #incl ...