Js学习基础

1:关于js中的数组

这里面可以是键值对的形式来存储的,我们必须利用forIn来输出,这就相当于foreach一样。

  1. var dir = new Array();
  2. dir['0'] = '1111';
  3. dir['1'] = '2222';
  4. dir['2'] = '3333';
  5. alert(dir['0']);
  6. for (var key in dir) {
  7.     alert('1'+key+'2'+dir[key]);
  8. }

键值对集合的形式

  1. var dicr = { '0': 'ahiu', '1': 'xiaohui', '2': 'aahui' };
  2. for (var key in dicr) {
  3.     alert(''+key+' '+dicr[key]);
  4. }

2:js中的String对象

CharAt(index)方法,获取指定索引位置的字符(索引从0开始)

  1. var meg = '啊四道口附近的回复';
  2. alert(meg.charAt(4));

indexOf('',startIndex):获取指定字符第一次出现的次数,startIndex表示从第几个开始找。

Split('分隔符',limit):根据分隔符将一个字符串返回一个数组,limit为返回数组的个数。

SubStr(startIndex,len):截取字符串,从第几个开始startIndex,截取几个字符len。

Substring(startIndex,stopIndex):截取字符串,从什么地方开始到什么地方结束。

ToUpperCase():转换大小写。

3:js中面向对象

à函数名小写,是函数,大写就是对象<js中叫做构造函数>。

à下面的是将person当作了普通的函数来调用。可以直接进行调用。

  1. function person() {
  2.  
  3. }
  4.  
  5. person();

à这里是当作对象来使用。当成类来使用

  1. function Person() {
  2.  
  3. }
  4.  
  5. var p = new Person();

à通过构造函数创建对象,且对象可以看成键值对集合,可以进行遍历(forIn)。这里的this就是我们的Person对象。就相当于创建了user_name,等变量。也可以直接点就可以直接创建。

  1. //通过构造函数创建Person对象
  2. function Person(name,age,email) {
  3.     this.user_name = name;
  4.     this.user_age = age;
  5.     this.user_email = email;
  6.     this.sayHello= function() {
  7.         alert(this.user_name+' '+this.user_age+' '+this.user_email);
  8.     }
  9. }
  10. var p = new Person('阿辉', '23', 'zhanghui.com');
  11. p.sayHello();

à通过对象字面量直接创建对象(集合初始化器)

  1. var p1 = {
  2.     user_name: 'ahui',
  3.     user_age: '23',
  4.     user_email: 'zhanghui.com',
  5.     sayHello: function() {
  6.         alert('大家好,才是真的好,我是:'+this.user_name);
  7.     },
  8.     sau_Hi: function() {
  9.         alert('ss'+this.user_email);
  10.     }
  11. };
  12. p1.sayHello();

4:instanceod判断哪个对象是那个类型

通过对象instanceof类型(),可以判断一个对象是否是某个类型。

  1. function person(parameters) {
  2.  
  3. }
  4. alert(person instanceof person);
  5. alert(person instanceof Object);

5:函数对象中的prototype属性:原型

解释:原型,雏形,蓝本。

每个方法可以存到原型对象。原型对象是个单独的对象,是减少程序的运行时间。比如申明两个相同的函数里面若只是方法不同,则这些方法不会保存到栈中,他们二者相同的部分都保存到prototype中。

利用这个来实现js的继承,关于原型对象,属性和方法都可以存进去,但是大多数存储的是方法。

一般的普通对象没有这个属性,只有函数对象才有,相当于父类的方法,但是孩子不继承它的。可是孩子对象可以访问到父类的prototype方法中方法。

  1. function Person(name,age,email) {
  2.     this.user_age = age;
  3.     this.user_email = email;
  4.     this.user_name = name;
  5. }
  6. //这里就是实现了js中的继承的关系
  7. Person.prototype.sayHello=function() {
  8.     alert('11'+this.user_name);
  9. };
  10. var p1 = new Person('第一', '23', '333');
  11. p1.sayHello();
  12. var p2 = new Person('第二', 'aaaa', '3333');
  13. p2.sayHello();

定义在prototype中的成员是所有对象共享的,所以一般讲方法定义在prototype中,而属性定义在构造函数中。通过该属性可以实现js的继承。不要为内置对象随便添加新成员,防止混乱,可以对自定义对象通过该方法添加新成员。

原型对象中的成员是只读的,不可以第二次的改变这个值。若是添加了,只是为其对象自己添加了个属性,并不是其原型中的值发生了改变。利用引用类型来理解就好了。

Eg:利用原型给现有类型添加方法。

  1.  String.prototype.addwjx = function() {
  2.      return
    this + 'bbb';
  3.  };
  4.  var msg = 'aaaa';
  5. msg=msg.addwjx();
  6.  alert(msg);

6:js中的继承<原型继承>

Js中没有类的概念,继承是通过对象和对象来实现的。这里的对象是new之后的。通过原型来使不同的对象之间关联起来。

  1. <script type="text/javascript">
  2.     function Person(name,age) {
  3.         this.user_name = name;
  4.         this.user_age = age;
  5.         this.sayHello = function() {
  6.             alert('我叫'+this.user_name+',今年'+this.user_age);
  7.         };
  8.     };
  9.     function Student(name) {
  10.         this.ahui_name = name;
  11.     };
  12.     var person = new Person('阿辉', '23');
  13.     Student.prototype = person; //这里实现了继承,通过原型来使对象和对象之间连接起来。
  14.     var s1 = new Student('小辉');
  15.     s1.user_name = '阿辉+';
  16.     s1.user_age = '23+';
  17.     s1.sayHello();
  18. </script>

 

JavaScript基础—插曲02的更多相关文章

  1. JavaScript基础第02天笔记

    JavaScript基础第02天 1 - 运算符(操作符) 1.1 运算符的分类 运算符(operator)也被称为操作符,是用于实现赋值.比较和执行算数运算等功能的符号. JavaScript中常用 ...

  2. JavaScript基础插曲-练习

    Javascript基础学习 eg:利用正则表达式来去掉空格. 1:msg=' Hello ': <script type="text/javascript">     ...

  3. JavaScript基础插曲—元素样式,正则表达式,全局模式,提取数组

    JavaScript基础学习 学习js的基础很重要,可以让自己有更多的技能.我相信这个以后就会用到. Eg:点击选择框,在div中显示出选择的数量 window.onload = function() ...

  4. JavaScript基础—插曲

    Javascript基础 1:js中我们最好使用单引号,其实可以使用双引号的但是为了区别所以js中全部使用单引号.注释和C#的是一样的.网页里面的执行顺序是从上到下依次执行的,不管你js放到哪里,都会 ...

  5. JavaScript基础插曲---apply,call和URL编码等方法

    Js基础学习 Js的压缩: 就是利用js的语法格式通过缩短变量名,去掉空格等来进行压缩. Apply和call的使用 1:apply方法:应用某一对象的方法,用于一个对象替换当前对象.主要是改变thi ...

  6. JavaScript基础插曲—获取标签,插入元素,操作样式

    Js基础 1:document.write() 这个是动态创建元素内容,利用js.这个可以利用js来创建元素,文本,标签等,document.write()与document.writeln()的区别 ...

  7. JavaScript基础精华02(函数声明,arguments对象,匿名函数,JS面向对象基础)

    函数声明 JavaScript中声明函数的方式:(无需声明返回值类型) function add(i1, i2) {             return i1 + i2;//如果不写return返回 ...

  8. JavaScript基本入门02

    目录 JavaScript基础入门 02 条件语句 if 语句 if .. else 语句 switch 结构 循环语句 while 循环 continue 关键字 do...while语句 for ...

  9. JavaScript基础语法资料

    JavaScript基础第01天 1 - 编程语言 1.1 编程 编程: 就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程. 计算机程序: 就是计算机所执行的一系列的 ...

随机推荐

  1. [渣译文] SignalR 2.0 系列:SignalR的服务器广播

    英文渣水平,大伙凑合着看吧…… 这是微软官方SignalR 2.0教程Getting Started with ASP.NET SignalR 2.0系列的翻译,这里是第八篇:SignalR的服务器广 ...

  2. 单一职责原则(Single Responsibility Principle)

    单一职责原则(SRP:The Single Responsibility Principle) 一个类应该有且只有一个变化的原因. There should never be more than on ...

  3. WPF 窗口自适应

    窗口自适应就是说,当主窗口缩放的时候,内部的控件位置自动的调整,而不是隐藏掉.这主要依赖于Grid布局. 1.比如这个groupbox 本身是在一个Grid的Row中的.缩放之后,左边的button不 ...

  4. 一个不陌生的JS效果-marquee,用css3来实现

    关于marquee,就不多说了,可以戳这里. 毕竟他是一个很古老的元素,现在的标准里头也不推荐使用这个标签了.但平时一些项目中会经常碰到这样的效果,每次都是重新写一遍,麻烦! JS类实现marquee ...

  5. 对map集合进行排序

          今天做统计时需要对X轴的地区按照地区代码(areaCode)进行排序,由于在构建XMLData使用的map来进行数据统计的,所以在统计过程中就需要对map进行排序. 一.简单介绍Map   ...

  6. java生成压缩文件

    在工作过程中,需要将一个文件夹生成压缩文件,然后提供给用户下载.所以自己写了一个压缩文件的工具类.该工具类支持单个文件和文件夹压缩.放代码: import java.io.BufferedOutput ...

  7. [51单片机] 以从0开始做4位8段共阴数码管3461AS驱动谈细节决定高质量DIY

    目录 1)问题产生 2)失败尝试 3)最终方案 4)使用方法 5)知识共享 1)问题产生 在上一篇“以PWM控制直流电机为例建一个简单的51工程框架”中已向大家介绍了一个封装好的8位8段数码管的驱动( ...

  8. NanoProfiler - 适合生产环境的性能监控类库 之 实践ELK篇

    上期回顾 上一期:NanoProfiler - 适合生产环境的性能监控类库 之 大数据篇 上次介绍了NanoProfiler的大数据分析理念,一晃已经时隔一年多了,真是罪过! 有朋友问到何时开源的问题 ...

  9. Git学习笔记(10)——搭建Git服务器

    本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...

  10. Oracle查询DQL脚本记录

    --查询列 Select t.sname,t.ssex,t.class from student t --t 别名; Select *from student t; --* 代表查询表内所有数据 '; ...