在js中,对样式的操作我们并不感到陌生,在很多框架中都是用极少的代码,实现更强大的功能,在这做出一些的总结。存在不足还望指出!

1、封装一个添加css的方法(这篇引用了前面的框架结构)

在 js 中 获得样式, 默认只能获得行内样式, 类样式与外部样式无法获得,

可以使用计算样式来获得第一次的结果window.getComputedStyle  获得style对象 建议第一次用
 注意: 如果是 低版本的 IE 浏览器, 需要使用 currentStyle

YY.fn.extend({
css: function(cssName,cssValue){
var style = window.getComputedStyle(this[0]);
return style[cssName];
}
}) I(function(){
var res = I('div').css('backgroundColor');
console.log(res);//获得样式值
console.log(typeof res );//string
})

上式是在一个参数情况下,获得可以获得样式值,如果两个参数值了,先考虑设置一个样式值的情况

YY.fn.extend({
css: function (cssName,cssValue){
if(cssValue === undefined){//判断是否有样式值,没有的话就返回
return window.getComputedStyle(this[0])[cssName];
}else{
return this.each(function (){
this.style[cssName]= cssValue;//给每个dom添加属性
});
}
}
})

下面可以设置多个样式值

YY.fn.extend({
css: function ( cssName, cssValue ) {
//判断是否为对象
if ( typeof cssName == 'object' ) {
// 给 this 中每一个 dom 对象都添加 样式
return this.each(function () {
var k;
for ( k in cssName ) {
this.style[ k ] = cssName[ k ];
}
                 //在这也可以用each方法做,不过要注意this指向的对象
                     YY.each(cssName,function(i,v){
                      _this.style[i] = cssName[ i ];
                     })*/
}); } else if ( cssValue === undefined ) { return window.getComputedStyle( this[ 0 ] )[ cssName ]; } else { // 给所有的元素都添加 该样式
return this.each(function () {
this.style[ cssName ] = cssValue;
});
}
}
});

2、封装关于class系列方法

判断类样式是否有class方法

YY.fn.extend({
hasClass: function ( cName ) { // cName 可能会是多个类样式
// 判断 this[ 0 ] 是否具有该类样式
var has = false;//事先定义一个has
YY.each(this[ 0 ].className.split( ' ' ), function ( i, v ) {
// console.log( this ); // 包装对象
// console.log( v ); // 字符串
if ( v === cName ) {//此处不能用this,this指向字符串数组
has = true;
return false;
}
});
return has; }
});

此处也可这么做

YY.fn.extend({
hasClass: function (cName){
return ( ' ' + this[ 0 ].className + ' ' ).indexOf(
' ' + YY.trim( cName ) + ' ' ) != -1;
}
})

添加class的方法

YY.fn.extend({

                addClass: function (cName){
return this.each(function){
// 在处理 CSS 类样式的时候, 实际上就是累加数据
//采用临时变量对其赋值,那么会预先在内存中加载计算,解决浏览器性能问题
var className += ' '+ cName;
//对类样式的空格做出处理
this.className = YY.trim(className);
}
}
});

移除class的方法
第一种方法

YY.fn.extend({
removeClass: function (cName){
return this.each(function(){
//将 DOM 对象的 className的字符串分割成数组
var arr = this.className.split(' '),
l = arr.length,
i;
for( i = 0;i < l;i++){
if(arr[i] === cName){
break;
}
}
//删除数组的第i项
arr.splice(i,1);
//然后把数组每一项放入一个新字符串
this.className = arr.join(' ');
})
} });

第二种方法

YY.fn.extend({
removeClass: function (cName){
// 将 this 中每一个 DOM 对象的 className 属性中符合 cName 的删除掉
return this.each(function(){
//获得DOM 对象的 className
var className = ' '+this.className+ ' ';
//直接将其替代为空
this.className = YY.trim(className.replace(' '+cName+' ',' '))
})
} });

在实现以上方法基础上就很容易实现toggle方法

YY.fn.extend({
toggleClass: function ( cName ) {
if ( this.hasClass( cName ) ) {
this.removeClass( cName );
} else {
this.addClass( cName );
}
}
});

关于js封装框架类库之样式操作的更多相关文章

  1. 关于js封装框架类库之DOM操作模块(二)

    上一篇基本实现了框架结构,但是与真正能用上的项目框架比较还是存在很多不足,在这又做了些加强与优化 (function ( window, undefined ) { var arr = [], pus ...

  2. 关于js封装框架类库之DOM操作模块(一)

    在前端开发的过程中,javascript极为重要的一个功能就是对DOM对象的操作,而对其封装就是为了更好地进行DOM操作,提高浏览器的支持效率 现在给出一个案例:页面创建三个div,然后给其添加样式 ...

  3. 关于js封装框架类库之属性操作

    在对DOM对象操作时,往往都要涉及到其属性的操作,为了提高开发效率,同时兼顾浏览器的性能,在这简单的封装了几个常见的属性.因为是模块化,在这只是引入了部分代码,其他代码在前几篇模块封装中有写.如有不足 ...

  4. 关于js封装框架类库之事件模块

    在触发DOM上的某个事件时,会产生一个事件对象event.这个对象中包含着所有与事件有关的信息.包括导致事件的元素,事件的类型以及其他与特定事件相关的信息. 例如: 鼠标操作点击事件时,事件对象中会获 ...

  5. 关于js封装框架类库之选择器引擎(一)

    选择器模块之传统做法 var tag = function (tag){ return document.getElementsByTagName(tag); } var id = function ...

  6. 关于js封装框架类库之选择器引擎(二)

    在上篇介绍了选择器的获取标签.id.类名的方法,现在我们在上篇基础上继续升级 1.问题描述:上篇get('选择器')已经实现,如果get方法里是一个选择器的父元素,父元素是DOM对象,那么如何获取元素 ...

  7. JS/jQuery--iframe框架内外元素的操作(转)

    JS/jQuery--iframe框架内外元素的操作 原创 2017年12月07日 14:23:09 标签: js / iframe 28 两个问题: 如何在父页面操作iframe框架内的元素? 如何 ...

  8. DOM操作标签、事件绑定、jQuery框架/类库

    DOM操作标签 ''' 在起变量名的时候 如果该变量指向的是一个标签 那么建议使用 xxxEle eg:aEle\pEle\divEle\spanEle ''' # 动态创建一个a标签并添加到页面指定 ...

  9. JS封装cookie操作函数实例(设置、读取、删除)

    本文实例讲述了JS封装cookie操作函数.分享给大家供大家参考,具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...

随机推荐

  1. Matlab 之meshgrid, interp, griddata 用法和实例

    http://blog.sina.com.cn/s/blog_67f37e760101bu4e.html 实例结果http://wenku.baidu.com/link?url=SiGsFZIxuS1 ...

  2. 如何自定义Intent.createChooser的显示结果

    Intent是android核心的概念之一,Intent为android系统提供了真正的开放.android的姿态是开放了,但却没有做到位. 拿“发邮件”这一功能来说,为了使用Intent机制来发送邮 ...

  3. WEKA,一个开源java的数据挖掘工具

    开始研究WEKA,一个开源java的数据挖掘工具. HS沉寂这么多天,谁知道偏偏在我申请离职的时候给我安排了个任务,哎,无语. 于是,今天看了一天的Weka. 主要是看了HS提供的三个文章(E文,在g ...

  4. MFC DLL资源动态切换

    在MFC使用过程中,遇到DLL资源与主EXE资源冲突问题. 出现这样的Bug,一时无从下手. 报错位置在核心代码中dlgcore.cpp. [cpp] view plaincopy BOOL AFXA ...

  5. COCOS2d-x简易安装步骤

    准备工作:1.    下载 cocos2d-x  下载地址:http://cdn.cocos2d-x.org/cocos2d-x-2.2.zip2.    下载 python 2.7.3 下载地址:h ...

  6. python第三天---collections类

    collection系列 1.计数器(counter) Counter是对字典类型的补充,用于追踪值的出现次数. 我们从中挑选一些相对常用的方法来举例: 在上面的例子我们可以看出,counter方法返 ...

  7. Xcode5新特性

    小引: 自从北京时间2013年06月11日苹果发布Xcode 5 Developer Preview 1,到现在,苹果也放出了Xcode 5 Developer Preview 3,速度还是蛮快的,希 ...

  8. AlarmManager类的应用

    1.AlarmManager,顾名思义,就是“提醒”,是Android中常用的一种系统级别的提示服务,可以实现从指定时间开始,以一个固定的间隔时间执行某项操作,所以常常与广播(Broadcast)连用 ...

  9. MATLAB一句总结

    MATLAB使用过程中的一些小总结: 1.sqrt函数的输入参数应为double类型: 2.im2bw把图像转换为二值图像: 3.double类型的图片必须转换为uint8类型后才能用imshow显示 ...

  10. eclipse开发工具Import工程后,工程文件夹上出现黄色感叹号——解决方法

    eclipse开发工具Import工程后,工程文件夹上出现黄色感叹号. 可能是Work目录无效,解决方法:删除Work目录即可,如下图所示: 删除后,如下图: