javascript中html字符串转化为jquery dom对象的方法


Posted in Javascript onAugust 27, 2015

原html字符串如下:

var text="<div id='overLay' style='width:50px;height:60px;background:url(imgs/back.png) left top no-repeat; position: absolute;'>"
        + "<img style='margin-left:4px;margin-top: 3px;' src='ima.png' width='43px' height='43px'/>"
        + "</div>";

 

1、下面使用Jquery库将text字符串变量转为Jquery对象。

Jquery代码如下:

alert($(text).html());

其中$(text)就text字符串转为了一个Jquery对象,最后将该Jquery对象的html()将html内容以字符串的形式输出,结果如下:

<img style='margin-left:4px;margin-top: 3px;' src='ima.png' width='43px' height='43px'/>

说明了,$(text)Jquery对象代表的是最外层的html元素div。

2、将Jquery对象和DOM对象之间互转。

代码如下:

var element= $(text).get(0) //element就是一个dom对象
var jqueryobj=$(element);//jqueryobj就是一个Jquery对象。

注意:DOM对象和Jquery对象区别

在我理解,Jquery对象和DOM对象都是封装的html元素,可以对html元素节点进行操作,方便编程,但是他们之间的方法有些是不能共用的,如Jquery对象的html()方法,DOM对象就使用不了;而DOM对象的GetElementById(),Jquery对象也不能使用。所以在必须要的时候可以进行相互转换。

3、使用js代码将text字符串变量转为DOM对象。

js代码如下:

/*字符串转dom对象*/
function loadXMLString(txt) 
{
  try //Internet Explorer
   {
     xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
     xmlDoc.async="false";
     xmlDoc.loadXML(txt);
     //alert('IE');
     return(xmlDoc); 
   }
  catch(e)
   {
     try //Firefox, Mozilla, Opera, etc.
      {
        parser=new DOMParser();
        xmlDoc=parser.parseFromString(txt,"text/xml");
       //alert('FMO');
        return(xmlDoc);
      }
     catch(e) {alert(e.message)}
   }
  return(null);
}

其中js代码将text字符串转为DOM对象与浏览器有关,所以。。。。。。分开写。

这样就实现了html字符串向Jquery对象和DOM对象的转换。

jQuery对象与dom对象相互转换方法介绍

刚开始学习jQuery,可能一时会分不清楚哪些是jQuery对象,哪些是DOM对象。至于DOM对象不多解释,我们接触的太多了,下面重点介绍一下jQuery,以及两者相互间的转换。

什么是jQuery对象?

---就是通过jQuery包装DOM对象后产生的对象。jQuery对象是jQuery独有的,其可以使用jQuery里的方法。

比如:

$("#test").html() 意思是指:获取ID为test的元素内的html代码。其中html()是jQuery里的方法

这段代码等同于用DOM实现代码:

document.getElementById("id").innerHTML;
虽然jQuery对象是包装DOM对象后产生的,但是jQuery无法使用DOM对象的任何方法,同理DOM对象也不能使用jQuery里的方法.乱使用会报错。比如:$("#test").innerHTML、document.getElementById("id").html()之类的写法都是错误的。

还有一个要注意的是:用#id作为选择符取得的是jQuery对象与document.getElementById("id")得到的DOM对象,这两者并不等价。请参看如下说的两者间的转换。

既然jQuery有区别但也有联系,那么jQuery对象与DOM对象也可以相互转换。在再两者转换前首先我们给一个约定:如果一个获取的是 jQuery对象,那么我们在变量前面加上$,如:var $variab = jQuery对象;如果获取的是DOM对象,则与习惯普通一样:var variab = DOM对象;这么约定只是便于讲解与区别,实际使用中并不规定。

jQuery对象转成DOM对象:

两种转换方式将一个jQuery对象转换成DOM对象:[index]和.get(index);

(1)jQuery对象是一个数据对象,可以通过[index]的方法,来得到相应的DOM对象。

如:

var $v =$("#v") ; //jQuery对象
var v=$v[0]; //DOM对象
alert(v.checked) //检测这个checkbox是否被选中

(2)jQuery本身提供,通过.get(index)方法,得到相应的DOM对象

如:

var $v=$("#v"); //jQuery对象
var v=$v.get(0); //DOM对象
alert(v.checked) //检测这个checkbox是否被选中

DOM对象转成jQuery对象:

对于已经是一个DOM对象,只需要用$()把DOM对象包装起来,就可以获得一个jQuery对象了。$(DOM对象)

如:

var v=document.getElementById("v"); //DOM对象
var $v=$(v); //jQuery对象

转换后,就可以任意使用jQuery的方法了。

通过以上方法,可以任意的相互转换jQuery对象和DOM对象。需要再强调注意的是:DOM对象才能使用DOM中的方法,jQuery对象是不可以用DOM中的方法。

Javascript 相关文章推荐
浅析JavaScript中的隐式类型转换
Dec 05 Javascript
浅谈 jQuery 事件源码定位问题
Jun 18 Javascript
jQuery实现视频作为全屏幕背景
Dec 18 Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 Javascript
基于AngularJS+HTML+Groovy实现登录功能
Feb 17 Javascript
D3.js中强制异步文件读取同步的几种方法
Feb 06 Javascript
jQuery插件zTree实现单独选中根节点中第一个节点示例
Mar 08 Javascript
关于vue-resource报错450的解决方案
Jul 24 Javascript
Vue3 源码导读(推荐)
Oct 14 Javascript
electron+vue实现div contenteditable截图功能
Jan 07 Javascript
Vue快速实现通用表单验证的方法
Feb 24 Javascript
微信小程序自定义yPicker组件实现省市区三级联动功能
Oct 29 Javascript
javascript 动态修改css样式方法汇总(四种方法)
Aug 27 #Javascript
JavaScript实现带箭头标识的多级下拉菜单效果
Aug 27 #Javascript
javascript引用类型之时间Date和数组Array
Aug 27 #Javascript
jQuery实现的数值范围range2dslider选取插件特效多款代码分享
Aug 27 #Javascript
jQuery手机拨号界面特效代码分享
Aug 27 #Javascript
JS实现自动切换文字的导航效果代码
Aug 27 #Javascript
javascript实现自动输出文本(打字特效)
Aug 27 #Javascript
You might like
磨咖啡豆的密诀
2021/03/03 冲泡冲煮
php fsockopen中多线程问题的解决办法[翻译]
2011/11/09 PHP
CI框架数据库查询缓存优化的方法
2016/11/21 PHP
Laravel5.1 框架路由基础详解
2020/01/04 PHP
js加载之使用DOM方法动态加载Javascript文件
2013/11/08 Javascript
jQuery插件zepto.js简单实现tab切换
2015/06/16 Javascript
七个不允许错过的jQuery小技巧
2015/12/21 Javascript
jquery.cookie.js用法实例详解
2015/12/25 Javascript
简单理解js的冒泡排序
2016/12/19 Javascript
Bootstrap table两种分页示例
2016/12/23 Javascript
js实现产品缩略图效果
2017/03/10 Javascript
分享十三个最佳JavaScript数据网格库
2017/04/07 Javascript
关于jquery form表单序列化的注意事项详解
2017/08/01 jQuery
js 奇葩技巧之隐藏代码
2017/08/11 Javascript
vue实现的组件兄弟间通信功能示例
2018/12/04 Javascript
一次让你了解全部JavaScript的作用域
2019/06/24 Javascript
layui 地区三级联动 form select 渲染的实例
2019/09/27 Javascript
JS自定义滚动条效果
2020/03/13 Javascript
用Angular实现一个扫雷的游戏示例
2020/05/15 Javascript
JavaScript语句错误throw、try及catch实例解析
2020/08/18 Javascript
深入理解NumPy简明教程---数组1
2016/12/17 Python
Python高斯消除矩阵
2019/01/02 Python
对django中foreignkey的简单使用详解
2019/07/28 Python
执行Django数据迁移时报 1091错误及解决方法
2019/10/14 Python
详解python 中in 的 用法
2019/12/12 Python
python对批量WAV音频进行等长分割的方法实现
2020/09/25 Python
Python3.9新特性详解
2020/10/10 Python
CSS3打造磨砂玻璃背景效果
2016/09/28 HTML / CSS
html5中监听canvas内部元素点击事件的三种方法
2019/04/28 HTML / CSS
MAC Cosmetics巴西官方网站:M·A·C彩妆
2019/04/18 全球购物
超市采购员岗位职责
2014/02/01 职场文书
个人房屋转让协议书范本
2014/10/26 职场文书
基层工作经验证明样本
2014/11/16 职场文书
2015年班级工作总结范文
2015/04/03 职场文书
「魔导具师妲莉亚永不妥协~从今天开始的自由职人生活~」1、2卷发售宣传CM公开
2022/03/21 日漫
简单聊聊Golang中defer预计算参数
2022/03/25 Golang