如何将jQuery对象转换为字符串?
我假设您要的是完整的HTML字符串。如果是这样的话,像这样的东西就可以达到目的:
$('<div>').append($('#item-of-interest').clone()).html();
这里将对此进行更深入的解释,但本质上,您将创建一个新节点来包装感兴趣的项,执行操作,删除它,并获取HTML。
如果你只是想要一个字符串表示,那么使用new string (obj)。
更新
我在2009年写了最初的答案。截至2014年,大多数主流浏览器现在都支持outerHTML作为原生属性(例如,Firefox和Internet Explorer),因此您可以:
$('#item-of-interest').prop('outerHTML');
你能说得更具体一点吗?如果你想让HTML在一个标签里面,你可以这样做:
HTML代码片段:
<p><b>This is some text</b></p>
jQuery:
var txt = $('p').html(); // Value of text is <b>This is some text</b>
jQuery在这里,所以:
jQuery.fn.goodOLauterHTML= function() {
return $('<a></a>').append( this.clone() ).html();
}
返回所有HTML内容:
$('div' /*elys with HTML text stuff that you want */ ).goodOLauterHTML(); // alerts tags and all
找出HTML节点(对象)可用的属性和方法的最好方法是这样做:
console.log($("#my-node"));
从jQuery 1.6+你可以使用outerHTML包括HTML标签在你的字符串输出:
var node = $("#my-node").outerHTML;
只需使用.get(0)来获取本机元素,并获取其outerHTML属性:
var $elem = $('<a href="#">Some element</a>');
console.log("HTML is: " + $elem.get(0).outerHTML);
可以使用jQuery.makeArray(obj)实用函数:
var obj = $('<p />',{'class':'className'}).html('peekaboo');
var objArr = $.makeArray(obj);
var plainText = objArr[0];
接受的答案不包括文本节点(未定义被打印出来)。
下面的代码片段解决了这个问题:
var htmlElements = $('<p><a href="http://google.com">google</a></p>↵↵<p><a href="http://bing.com">bing</a></p>'), htmlString = ''; htmlElements.each(function () { var element = $(this).get(0); if (element.nodeType === Node.ELEMENT_NODE) { htmlString += element.outerHTML; } else if (element.nodeType === Node.TEXT_NODE) { htmlString += element.nodeValue; } }); alert('String html: ' + htmlString); <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
如果你想对一个HTML元素进行字符串化,以便将它传递到某个地方并解析回一个元素,请尝试为该元素创建一个唯一的查询:
// 'e' is a circular object that can't be stringify
var e = document.getElementById('MyElement')
// now 'e_str' is a unique query for this element that can be stringify
var e_str = e.tagName
+ ( e.id != "" ? "#" + e.id : "")
+ ( e.className != "" ? "." + e.className.replace(' ','.') : "");
//now you can stringify your element to JSON string
var e_json = JSON.stringify({
'element': e_str
})
than
//parse it back to an object
var obj = JSON.parse( e_json )
//finally connect the 'obj.element' varible to it's element
obj.element = document.querySelector( obj.element )
//now the 'obj.element' is the actual element and you can click it for example:
obj.element.click();
推荐文章
- JSHint和jQuery: '$'没有定义
- 用jQuery检查Internet连接是否存在?
- 如何使用滑动(或显示)函数在一个表行?
- 如何用JavaScript截屏一个div ?
- 如何检测“搜索”HTML5输入的清除?
- 当元素从DOM中移除时触发事件
- Ajax成功事件不工作
- 引导下拉与Hover
- jQuery的.bind() vs. on()
- jQuery .live() vs .on()方法,用于在加载动态html后添加单击事件
- 事件。returnValue已弃用。请使用标准的event.preventDefault()
- 如何处理模式关闭事件在Twitter引导?
- 防止浏览器加载拖放文件
- 清除输入文本内的图标
- jQuery为ajax请求返回“parsererror”