通过上一节面向对象和原型的学习。

我们知道了怎样创建一个类,包含类的私有化属性和方法、公有化属性和方法、静态属性和方法。在这里略微回想一下。首先要创建一个类能够通过1.new object()。2.利用构造函数function Person(){},然后通过new Person()。另一种是通过字面量的方式创建一个对象,通过字面量的方式不能使用new运算符,由于他是在内部自己new object()。

在这里我们要对类和对象有一定的区分,形象的来说,假设动物是一个类的话。人能够是当中一个对象。就上面的var
person = new Person();这里的Person就是一个类。而person则是他的一个实例化对象,并且能够有非常多派生的类,比方Man.prototype = new Person(); var man = new Man();那么这个man也是一个实例化对象。简单的说,类是虚的,而对象是实体的。了解了对象和类的差别之后。我们简单看下怎样创建类的私有化。公有化以及静态属性和方法。

面向对象的知识

var a = function(){
var private1 = 'private1'; //私有字段
this.public1 = 'public1'; //共同拥有字段,实例字段
var privateMethod1 = function(){ //私有方法
alert('privateMethod1');
}
this.publicMethod1 = function(obj){ //公共方法。实例方法
private1 = obj;
}
this.publicMethod2 = function(){ //公共方法
return private1;
}
}
a.filed1 = 'filed1'; //公共静态字段
var b1 = new a();
var b2 = new a();
b1.publicMethod1('ss');
console.log(b1.publicMethod2());
console.log(b2.publicMethod2()); **************************************************** var a = (function(){
//console.log(this); //window对象
var private1 = 'private1'; //这个是私有静态属性
this.public1 = 'public1';
return function(){
//console.log(this); //object对象
this.publicMethod1 = function(obj){
private1 = obj;
}
this.publicMethod2 = function(){
//console.log(this); //返回的对象的实例
return private1;
}
}
})(); var b1 = new a();
var b2 = new a();
b1.publicMethod1('s');
console.log(b1.publicMethod2());
console.log(b2.publicMethod2());

第一个类库base.js

了解了主要的面向对象和原型后。我们来封装我们第一个类库。

这个类有下面功能:能够通过id,class,tagname获取元素,实现连缀功能,设置css,获取文本等主要的功能:

var $ = function(){
return new Base();
} var Base = function(){
this.elements = []; //代表元素集合
} //利用Id获取元素
Base.prototype.fId = function(id){
this.elements.push(document.getElementById(id));
return this;
} //利用tagName获取元素
Base.prototype.fTag = function(tag){
var eles = document.getElementsByTagName(tag);
for(var i = 0,len = eles.length; i < len; i++){
this.elements.push(eles[i]);
}
return this;
}; //利用className获取元素
Base.prototype.fClass = function(className){
var eles = document.getElementsByClassName(className);
for(var i = 0,len = eles.length; i < len; i++){
this.elements.push(eles[i]);
}
return this;
}; //文本值
Base.prototype.fText = function(str){
var texts = [];
//获取innerHTML的值
function getInnerHTML(i,that){
texts.push(that.elements[i].innerHTML);
};
//设置innerHTML的值
function setInnerHTML(i,that,str){
that.elements[i].innerHTML = str;
};
//获取nodeValue的值
function getNodeValue(i,that){
texts.push(that.elements[i].firstChild.nodeValue);
};
//设置nodeValue的值
function setNodeValue(i,that,str){
that.elements[i].firstChild.nodeValue = str;
};
if(arguments.length === 0){
typeof this.elements[0].innerHTML != "undefined"?lenFor(getInnerHTML,this):lenFor(getNodeValue,this);
return texts;
}else if(arguments.length === 1){
typeof this.elements[0].innerHTML != "undefined"?lenFor(setInnerHTML,this,str):lenFor(setNodeValue,this,str);
return this;
}
};
/*
if(arguments.length === 0){ //假设不输入參数则觉得是获取文本值
if(typeof this.elements[0].innerHTML != "undefined"){
var getInnerHTML = function(){
texts.push(this.elements[i].innerHTML);
}
}else{
for(var i = 0,len = this.elements.length; i < len; i++){
texts.push(this.elements[i].firstChild.nodeValue);
}
}
return texts;
}else if(arguments.length === 1){ //假设输入參数则觉得是设置文本值
if(typeof this.elements[0].innerHTML != "undefined"){
for(var i = 0,len = this.elements.length; i < len; i++){
this.elements[i].innerHTML = str;
}
}else{
for(var i = 0,len = this.elements.length; i < len; i++){
this.elements[i].firstChild.nodeValue = str;
}
}
return this;
}
*/ //设置和获取CSS值
Base.prototype.fCss = function(cssName,cssValue){
var cssStrs = [];
//获取getComputedStyle的值
function getFFStyle(i,that,cssName){
var style = window.getComputedStyle(that.elements[i]);
cssStrs.push(style[cssName]);
};
//获取currentStyle的值
function getIEStyle(i,that,cssName){
var style = that.elements[i].currentStyle;
cssStrs.push(style[cssName]);
};
//设置css的值,当中float为保留字,IE为styleFloat,FF为cssFloat
function setCss(i,that,cssName,cssValue){
that.elements[i].style[cssName] = cssValue;
};
if(arguments.length === 1){
typeof window.getComputedStyle != "undefined"? lenFor(getFFStyle,this,cssName):lenFor(getIEStyle,this,cssName);
return cssStrs;
}else if(arguments.length === 2){ //设置CSS的值
lenFor(setCss,this,cssName,cssValue);
return this;
}
}; //加入css类选择器
Base.prototype.addCssClass = function(className){
//获取elements的class值
function add(i,that,className){
var name = that.elements[i].className;
var partern = new RegExp("(^|\\s)" + className + "($|\\s)","g");
if(!partern.test(name)){
name += " " +className;
}
that.elements[i].className = name;
};
lenFor(add,this,className);
return this;
}; //删除css类选择器
Base.prototype.removeCssClass = function(className){
//删除elements的class值
function remove(i,that,className){
var name = that.elements[i].className;
var partern = new RegExp("(^|\\s)" + className + "($|\\s)","g");
that.elements[i].className = name.replace(partern,"");
};
lenFor(remove,this,className);
return this;
}; //对elements进行循环,并运行fn函数
function lenFor(fn,that,str,str1){
for(var i = 0,len = that.elements.length; i < len; i++){
fn(i,that,str,str1);
}
};

这是第一个类库的雏形,还没有进行优化。待日后学习后进行优化。其它的类库将在这个基本库的基础上进行拓展。以添加其功能。

JavaScript-创建第一个自己的类库的更多相关文章

  1. 创建ArcGIS API for JavaScript的第一个示例程序

    原文:创建ArcGIS API for JavaScript的第一个示例程序 在上一篇博客中已经介绍了如何搭建ArcGIS API for JavaScript开发环境,如果您还没有搭建好开发环境的话 ...

  2. ASP.NET MVC 5 03 - 安装MVC5并创建第一个应用程序

    不知不觉 又逢年底, 穷的钞票 所剩无几. 朋友圈里 各种装逼, 抹抹眼泪 MVC 继续走起.. 本系列纯属学习笔记,如果哪里有错误或遗漏的地方,希望大家高调指出,当然,我肯定不会低调改正的.(开个小 ...

  3. ThinkPHP学习(二)理清ThinkPHP的目录结构及访问规则,创建第一个控制器

    ThinkPHP的目录结构 回顾上一篇的安装目录: 目录对应关系 F:\\PHP├─index.php       入口文件├─README.md       README文件├─Applicatio ...

  4. 你不知道的javaScript上卷(第一章 作用域是什么)

    在写这篇博客时这本书我已经是看过一遍了,为了加深印象和深入学习于是打算做这系列的前端经典书籍导读博文,大家如果觉得这本书讲的好可以自己买来看看,我是比较喜欢看纸质版书的,因为这样才有读书的那种感觉. ...

  5. Angular安装及创建第一个项目

    Angular简介 AngularJS 诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀的前端JS框架,已经被用于Google的多款产品当中.AngularJ ...

  6. Ionic学习记录(一):ionic及cordova安装、创建第一个应用、项目结构

    目录: 一.ionic的安装 二.创建第一个应用程序 三.浏览器中预览应用 四.项目结构 五.添加页面 一.ionic的安装 使用Ionic创建和开发应用程序主要通过Ionic命令行实用程序(“CLI ...

  7. AngularJs轻松入门(一)创建第一个应用

    AngularJs是Google工程师研发的一款JS框架,官方文档中对它的描述是,它是完全使用JavaScript编写的客户端技术,同其他历史悠久的Web技术(HTML,CSS等)配合使用,使得Web ...

  8. 如何在前端通过JavaScript创建修改CAD图形

    背景 在之前的博文CAD图DWG解析WebGIS可视化技术分析总结.CAD_DWG图Web可视化一站式解决方案-唯杰地图-vjmap中讲解了如何把CAD的DWG格式的图纸Web可视化的方案,那在Web ...

  9. 用html5的canvas和JavaScript创建一个绘图程序

    本文将引导你使用canvas和JavaScript创建一个简单的绘图程序. 创建canvas元素 首先准备容器Canvas元素,接下来所有的事情都会在JavaScript里面. <canvas ...

  10. BI之SSAS完整实战教程3 -- 创建第一个多维数据集

    上一篇我们已经完成了数据源的准备工作,现在我们就开始动手,创建第一个多维数据集(Cube). 文章提纲 使用多维数据集向导创建多维数据集 总结Cube设计器简介 维度细化 总结 一.使用向导创建多维数 ...

随机推荐

  1. 南邮CTF--SQL注入题

    南邮CTF--SQL注入题 题目:GBK SQL injection 解析: 1.判断注入点:加入单引号发现被反斜杠转移掉了,换一个,看清题目,GBK,接下来利用宽字节进行注入 2.使用'%df' ' ...

  2. luogu3302 [SDOI2013]森林

    前置技能:Count on a tree 然后带上一个启发式合并 #include <algorithm> #include <iostream> #include <c ...

  3. 大数据学习——linux系统的网卡配置步骤

    ifconfig 查看ip,没有ip时需要配置 配置步骤: 1输入命令setup,选择network configuration,选择runtool,选择device configuration,选择 ...

  4. C#窗体学生成绩管理系统

    c#学生成绩管理系统 实现用户登录.注册 所有成绩查询.个人成绩查询 管理员审核.添加.删除用户 项目源码GIT:https://github.com/soulsjie/StuScoreMa.git

  5. SPOJ DCEPC11I

    题目大意: 就是给定一段区间令其中的数增加一个递增序列(也就是说第一个+1,第二个+2.....) 询问操作是区间的和 这里的查询很简单,但是对于添加递增序列入区间就比较搞脑子了 我们需要一个add[ ...

  6. CSU1350 To Add which?

    题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1350 这题目因为每一个数都跟相邻的数有关,所以可以从左到右和从右到左一次扫一遍即可 代 ...

  7. hdu 2845简单dp

    /*递推公式dp[i]=MAX(dp[i-1],dp[i-2]+a[j])*/ #include<stdio.h> #include<string.h> #define N 2 ...

  8. java中filter的用法

    filter过滤器主要使用于前台向后台传递数据是的过滤操作.程度很简单就不说明了,直接给几个已经写好的代码: 一.使浏览器不缓存页面的过滤器 Java代码   import javax.servlet ...

  9. C++动态特性和C++对象模型——《高质量程序设计12章》

    1.动态特性 静态特性和动态特性,编译时和运行时 虚函数 (1)虚函数的叫覆盖,虚函数不是实现多态的唯一手段(其他语言也可能采用别的方法). 抽象基类: (1)如果将基类的虚函数声明为纯虚函数,则基类 ...

  10. Python基础之 一 文件操作

    文件操作 流程: 1:打开文件,得到文件句柄并赋值给一个变量 2:通过句柄对文件进行操作 3:关闭文件 模式解释 r(读) , w(写) ,a(附加)r+(读写的读), w+(读写的写),a+(读附加 ...