原生js 样式的操作整理

内联样式的获取

 function getStyle(obj,attr){//简单的获取内联样式
		 return  obj.currentStyle?obj.currentStyle[attr]:obj.getComputedStyle(obj,false)[attr];
	  }
 

下面是比较完善的,

 //参考地址 http://stylechen.com/getstyle2.html
var getStyle = function( elem, style ){ //单位如果em或%的单位,getComputedStyle()返回的值就会自动将em或%换成px的单位,currentStyle就不会,而如果是font-size使用em为单位,在Opera下返回的是0em,Opera真的很恐怖!
	return ‘getComputedStyle‘ in window ?
	getComputedStyle( elem, null )[style] :
	function(){
		style = style.replace( /\-(\w)/g, function( $, $1 ){
			return $1.toUpperCase();
		});

		var val =  elem.currentStyle[style];

		if( val === ‘auto‘ && (style === "width" || style === "height") ){
			var rect =  elem.getBoundingClientRect();
			if(	style === "width" ){
				return rect.right - rect.left + ‘px‘;
			}else{
				return rect.bottom - rect.top + ‘px‘;
			}
		}
		return val;
	}();
};
 

// 调用该方法
//var test = document.getElementById( ‘test‘ ),
      // 获取计算的宽度
//tWidth = getStyle( test, ‘width‘ );

原生获取className

function getClass(parent,className,tagName){
	//var parent = parent || document,
	var parent = !!(parent != undefined&&parent.nodeType==1)?parent:document, //parent参数是可选的,但需要先判断它是否存在,且是节点dom元素 parent != undefined&&parent.nodeType==1 ,nodeType == 1可以判断节点是否为dom元素,在火狐浏览器里面,空白也算是节点(.childnodes),用这个属性就判断是否为dom元素,排除空白符.
	    tagName = tagName || "*";  //alert(parent.nodeName); //ul
	if(parent.getElementsByClassName){
		return parent.getElementsByClassName(className);
    }else{
		var aEls =parent.getElementsByTagName(tagName),arr = [],re=new RegExp(‘(^|\\s)‘+className+‘($|\\s)‘);
		for (var i = 0; i < aEls.length; i++) {
			re.test(aEls[i].className) && arr.push(aEls[i]);
		};
		return arr;
	};
} ;  //获取class (因为获取一组元素集合,如果单个使用一定要加[0]下标,不然会报错)
 

添加样式

 
function addClass(ele,cls) {
   if (!this.hasClass(ele,cls)) ele.className += " "+cls;
} 
 
另外一种比较好的
function addclass(elm,cls){   //  参考地址 :http://www.ghugo.com/transfer-should-have-known-7-javascript-skills/
  var classes = elm.className.split(‘ ‘);
  classes.push(cls);
  elm.className = classes.join(‘ ‘);
}

已有样式

function hasClass(ele,cls) {
     return ele.className.match(new RegExp(‘(\\s|^)‘+cls+‘(\\s|$)‘));}

移除样式

function removeClass(ele,cls) {
  if (hasClass(ele,cls)) {
  var reg = new RegExp(‘(\\s|^)‘+cls+‘(\\s|$)‘);
   ele.className=ele.className.replace(reg,‘ ‘);
  }
}

以上是利用了原生js对样式的操作获取

Html5新增的api接口,

<script>
/*!
 * classie - class helper functions
 * from bonzo https://github.com/ded/bonzo
 *
 * classie.has( elem, ‘my-class‘ ) -> true/false
 * classie.add( elem, ‘my-new-class‘ )
 * classie.remove( elem, ‘my-unwanted-class‘ )
 * classie.toggle( elem, ‘my-class‘ )
 */

/*jshint browser: true, strict: true, undef: true */
/*global define: false */

;( function( window ) {

‘use strict‘;

// class helper functions from bonzo https://github.com/ded/bonzo

function classReg( className ) {
  return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
}

// classList support for class management
// altho to be fair, the api sucks because it won‘t accept multiple classes at once
var hasClass, addClass, removeClass;

if ( ‘classList‘ in document.documentElement ) {
  hasClass = function( elem, c ) {
    return elem.classList.contains( c );
  };
  addClass = function( elem, c ) {
    elem.classList.add( c );
  };
  removeClass = function( elem, c ) {
    elem.classList.remove( c );
  };
}
else {
  hasClass = function( elem, c ) {
    return classReg( c ).test( elem.className );
  };
  addClass = function( elem, c ) {
    if ( !hasClass( elem, c ) ) {
      elem.className = elem.className + ‘ ‘ + c;
    }
  };
  removeClass = function( elem, c ) {
    elem.className = elem.className.replace( classReg( c ), ‘ ‘ );
  };
}

function toggleClass( elem, c ) {
  var fn = hasClass( elem, c ) ? removeClass : addClass;
  fn( elem, c );
}

var classie = {
  // full names
  hasClass: hasClass,
  addClass: addClass,
  removeClass: removeClass,
  toggleClass: toggleClass,
  // short names
  has: hasClass,
  add: addClass,
  remove: removeClass,
  toggle: toggleClass
};

// transport
if ( typeof define === ‘function‘ && define.amd ) {
  // AMD
  define( classie );
} else {
  // browser global
  window.classie = classie;
}

})( window );
</script>
 
 
 
 
以上的缺点:只能添加单个样式  elem.classList.add( classNameOne );   需要自己完善
时间: 2024-10-07 01:20:32

原生js 样式的操作整理的相关文章

原生JS与jQuery操作DOM有什么异同点?

本文和大家分享的主要是原生JS与jQuery操作DOM相关内容,一起来看看吧,希望对大家学习javascript有所帮助. 一.创建元素节点 1.1 原生 JS 创建元素节点 document.createElement("p"); 1.2 jQuery 创建元素节点 $('<p></p>');` 二.创建并添加文本节点 2.1 原生JS创建文本节点 document.createTextNode("Text Content"); 通常创建文

原生js和Jquery操作DOM

原生javascript和jQuery操作DOM的对比总结 目录: DOM元素节点:1)文档节点:2)元素节点:3)属性节点:4)文本节点:5)注释节点 1)创建节点 2)选择(访问)节点 3)操作: 1)节点操作 1)添加节点 2)删除节点 3)修改内容: 1)文本[text] 2)html 3)表单val 4)改变事件 2)CSS操作 3)动画 下文转自:http://www.jb51.net/article/103583.htm 这篇文章主要给大家介绍了原生JS和jQuery操作DOM的一

原生JS和jQuery操作DOM的区别小结

一.Js原生对象和jQuery实例对象的相互转化: (1).原生JS对象转JQ对象: $(DOM对象); (2). JQ对象转原生JS对象: $(DOM对象).get(index); //注意区分eq(index)是jQuery实例对象; 直接下标访问, $(DOM对象)[index]; 二.两者操作DOM的对比 一.创建元素节点 1.1 原生JS创建元素/文本节点 1 document.createElement("p"); 1.2 jQuery创建元素/文本节点 1 $('<

原生js与jQuery操作DOM的区别

转自网络 一.创建元素节点 1.1 原生JS创建元素节点 ? 1 document.createElement("p"); 1.2 jQuery创建元素节点 ? 1 $('<p></p>');` 二.创建并添加文本节点 2.1 原生JS创建文本节点 ? 1 `document.createTextNode("Text Content"); 通常创建文本节点和创建元素节点配合使用,比如: ? 1 2 3 var textEl = documen

js前端一些操作整理

异步加载js, function loadScript(url, callback){ var script = document.createElement("script") script.type = "text/javascript"; if (script.readyState){ //IE script.onreadystatechange = function(){ if (script.readyState == "loaded"

原生JS与jQuery操作DOM对比

一.创建元素节点 1.1 原生JS创建元素节点 document.createElement("p"); 1.2 jQuery创建元素节点 $('<p></p>');` 二.创建并添加文本节点 2.1 原生JS创建文本节点 document.createTextNode("Text Content"); 通常创建文本节点和创建元素节点配合使用,比如: var textEl = document.createTextNode("Hel

整理一下原生js的dom操作

获取元素 getElementById() getElementsByClass() getElementsByTagName getElementsByName node属性 前.后.父.子 previousSibling nextSibling parentNode childNode children firstChild lastChild 操作 appendChild insertBefore removeChild replaceChild innerHtml innerText 创

dom操作原生js巩固

原生js的dom操作巩固 前言:这玩意其实很简单,但是每次用的时候都有点含糊,故写个文章,每次忘得时候看一看 原生dom操作 1.创建dom元素:createElement(标签名) 2.删除dom元素:removeChild(标签名) 3.在什么元素后添加dom元素:元素.appendChild(标签名) 4.在什么元素前添加dom元素:元素.insertBefore(标签名) 5.替换dom元素:replace(插入的元素,被替换的元素) 6.获取父节点:parentNode 7.获取子节点

原生js 与 jQuery对比

1.原生JS与jQuery操作DOM对比  :   https://www.cnblogs.com/QianBoy/p/7868379.html 2.比较jQuery与JavaScript的不同功能实现   :   http://www.cnblogs.com/QianBoy/p/7868291.html 原文地址:https://www.cnblogs.com/wfblog/p/9178892.html