05_Javascript进阶第二天
- String对象
res=str.charAt(1);//返回字符串中第n个字符(输出:i)
res=str.charCodeAt(1);//返回第n个字符的ASCII编码(输出:105)
res=String.fromCharCode(105,97);//根据ASCII编码返回指定字符,可指定多个(输出:ia)
res=str.concat('yes');//连接字符串,相当于连接符+(输出:Will you set sail tonight?yes)
res=str.indexOf('you',3);//查找字符串'you'首次出现的位置,指定从下标3开始查找(输出:5)
//通过indexOf可以统计一个字符在字符串中出现的次数
function _count(str,search){
var count=0,n=0;
while(n!=-1){
count++;
n=str.indexOf(search,n+1);
}
return count;
}
var num=_count('abcaabs','a');
console.log('count:'+num); res=str.lastIndexOf('you');//返回查找字符最后一次出现的位置,实际上是从后面开始查找(输出:25)sort的排序原理是什么?
//localCpmpare比较字符串(实现中文按照字母排序)
var array = ['白鸽', '麻雀', '大象', '狗', '猫', "鸡"];
array = array.sort(
function compareFunction(item1, item2) {
return item1.localeCompare(item2);
}
);
//输出:"白鸽,大象,狗,鸡,麻雀,猫"
var arr=[6,1,3,5,2,8]
arr=arr.sort(
function(x,y){
return x>y;//从小到大排序
}
)
输出:"1,2,3,5,6,8"match匹配,search搜索,replace代替
var str='this is a test';
var res;
res=str.match('is');//输出:["is", index: 2, input: "this is a test"]
res=str.search('is');//输出:2
res=str.replace(/is/g,'?');//全局匹配。输出:"th? ? a test",如果不加g,只替换第一个is
str='2017-12-9';
res=str.replace(/(\d{4})-(\d{2})-(\d{1,2})/,'$2/$3/$1');//输出:"12/9/2017"
//用函数实现
res=str.replace(/(\d{4})-(\d{2})-(\d{1,2})/,func);
function func(match,d1,d2,d3){
// return d2+'/'+d3+'/'+d1;
return [d2,d3,d1].join('/'); }
console.log(res);字符串截取
var str='abcde';
var res;
//slice(start.end),返回截取后的字符串
//substr(start,length),返回截取之后的字符串
//split(delimiter[,limit]),将字符串拆分为数组
res=str.slice(0,-1);//输出:abcd
res=str.substr(2,2);//输出:cd str='red,green,blue';
res=str.split(',',2);//2是可选参数,表示返回两个元素,输出:"red,green"其他
//字符串大小写相关
str='HELLO world';
res=str.toLowerCase();//换成小写
res=str.toLocaleLowerCase();//也是换成小写
res=str.toUpperCase();//大写 //trim字符串过滤
str=' hello world ';
res=str.trim();//去掉了前后的空格 //产生锚点
str='this is a test';
document.body.innerHTML=str.anchor('anchor_name');//<a name="anchor_name">this is a test</a>
//产生链接
var title='百度';
var url="http://www.baidu.com";
document.write(title.link(url));\n
//<a href="http://www.baidu.com">百度</a> - Function对象
属性:var res;
function a(x,y,z){
return x+y+z;
}
//1、constructor返回创建该对象的构造函数
res=a.constructor;//输出:function Function() { [native code] } //2、length返回函数的参数个数
res=a.length;//输出:3 //3、caller返回调用当前函数的函数
function f1(){
return f1.caller;
}
function f2(){
return f1();
}
res=f2();
//输出:"function f2(){return f1();}" //4、arguments返回由函数的所有参数组成的数组
function a(){
return arguments;
}
res=a(1,2,'c');//输出:[1, 2, "c", callee: function, Symbol(Symbol.iterator): function] //arguments有个callee属性,返回当前被调用的函数对象 function a(){
return arguments.callee;
}
res=a();
//输出:function a(){……}
//可以利用callee属性实现匿名函数的自身调用
(function(count){
if(count<=3){
alert(count);
arguments.callee(++count);
}
})(0);call和apply方法
//call回调函数
var obj={
say:function(x,y){return x+y;}
};
var obj1={};
res=obj.say.call(obj1,1,2);//obj1调用obj的方法,1,2是参数
res=obj.say.apply(obj,[2,3]);//跟call方法差不多,只不过参数以数组形式传递 - Math对象,不是函数对象
var res;
res=Math.E;//输出: "2.718281828459045"
res=Math.PI;//输出:"3.141592653589793"
res=Math.abs(-123);//取绝对值,输出:123
res=Math.ceil(2.14);//向上取整,输出:2
res=Math.floor(2.82);//向下取整,输出:2
res=Math.round(2.45);//四舍五入,输出:2
res=Math.pow(2,3);//2的3次方根,输出:8
res=Math.sqrt(16);//开方根,输出:4
res=Math.max(1,45,6);//求最大值,输出:45
console.log(res) - 对象的原型prototype
function product(name,color){
this.name=name;
this.color=color;
this.say=function(){return 'this is a test';};
}
product.prototype.price=123;
product.prototype.memory=32;
var p1=new product('苹果手机','白色');
//new运算符,函数里面的this自动指向创造的对象,product函数里面的this指代p1,
//所以p1有3个自身属性,price和memory是原型链的属性
for(var i in p1){
//判断是否是自身属性
if(p1.hasOwnProperty(i)){
console.log(p1[i]);//不能用p1.i
} } - 内建对象的扩展
String.prototype.reverse=function(){
return Array.prototype.reverse.apply(this.split('')).join('');
}
console.log('abc'.reverse());//输出:cba //检测方法是否存在,不存在则扩展
if(!Array.prototype.inArray){
// alert('no');
Array.prototype.inArray=function(search){
for(var i=0;i<this.length;i++){
if(this[i]==search){
return true;
}
}
return false;
}
} var arr=['a','b','c'];
console.log(arr.inArray('A')); - 13章后看不下去,继承,原型链什么的……
05_Javascript进阶第二天的更多相关文章
- 05_Javascript进阶第一天
内部私有函数 function a(){ alert('aaa'); return function b(){ alert('bbb'); } } //调用内部私有函数b,方法1 var func=a ...
- jQuery进阶第二天(2019 10.10)
一.事件流程 1.事件的三要素: 事件源:发生事件的对象 事件类型:类型比如单击.双击.鼠标的移入.移除 事件处理程序: 触发事件之后做些什么,事件处理的函数 <body> <but ...
- 汇编语言进阶和Makefile进阶---第二天
摘要: 原创博文:转载请标明出处:http://www.cnblogs.com/zxouxuewei 首先加载启动代码: ; hello-os ; TAB=4 ORG 0x7c00 ; 指明程序装载地 ...
- iOS 进阶 第二十二天(0603)
0603 block\运行时 block block的本质是一个指向结构体的指针. 运行时 要分析clang命令反编译出来的c++代码,就要把一些小括号删掉来分析.因为这些小括号一般都是类型强转. o ...
- iOS 进阶 第二天(0324)
0324 创建transform transform 是形变属性. 如下图: 如果按照上面的方法来创建的话是这样解释:是相对初始状态来说的,不会在变化后的基础上进行形变.如果要持续变化就要自己去不断改 ...
- lvs 进阶 第二章
linux virtual server 一 . lvs lvs 对数据进行四层转发,根据目标地址和目标端口对请求数据进行转发. lvs 包含ipvsadm 和ipvs: ipvsadm :用户空间的 ...
- Linux入门进阶第二天——软件安装管理(上)
一.大纲介绍 这里介绍的仅仅是两大家族之一的RPM,关于Debian家族的DPKG,请参考:http://justcoding.iteye.com/blog/1937171 二.简介 软件包分类: 源 ...
- 题解:swj社会摇进阶第二课
题目链接 思路:按题目推一点点可以得出答案为 sigma (i-k)*n/i+d(n%i>=k) #include<bits/stdc++.h> using namespace st ...
- 前端开发入门到进阶第二集【emmet插件的使用技巧】
Emmet (前身为 Zen Coding) 是一个能大幅度提高前端开发效率的一个工具.基本上,大多数的文本编辑器都会允许你存储和重用一些代码块,我们称之为"片段".虽然片段能很好 ...
随机推荐
- php 抽象类和接口类
PHP中抽象类和接口类都是特殊类,通常配合面向对象的多态性一起使用. 相同: ①两者都是抽象类,都不能实例化. ②只有接口类的实现类和抽象类的子类实现了 已经声明的 抽象方法才能被实例化. 不同: ① ...
- 2017-07-18&19
[toc] 数据库 for循环里写操作数据库是大忌!尤其是这种情况:一次查询的结果中有一个记录还要继续展开查询,两次查询的记录均不止一条.就很容易写成for循环里操作数据库了.解决办法就是循环里的每条 ...
- 内核知识第八讲,PDE,PTE,页目录表,页表的内存管理
内核知识第八讲,PDE,PTE,页目录表,页表的内存管理 一丶查看GDT表. 我们通过WinDbg + 虚拟机可以进行双机调试.调试一下看下GDT表 我们知道,GDT表中.存储的是存储段信息. 保存了 ...
- 2017"百度之星"程序设计大赛 - 复赛1003&&HDU 6146 Pokémon GO【数学,递推,dp】
Pokémon GO Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- android组件化方案、二维码扫码、Kotlin新闻客户端、动画特效等源码
Android精选源码 CalendarView日历选择器 android下拉刷新动画效果代码 一个非常方便的fragment页面框架 android组件化方案源码 Zxing实现二维码条形码的扫描和 ...
- iOS项目——项目开发环境搭建
在开发项目之前,我们需要做一些准备工作,了解iOS扩展--Objective-C开发编程规范是进行开发的必备基础,学习iOS学习--Xcode9上传项目到GitHub是我们进行版本控制和代码管理的选择 ...
- parseInt原来是这样用的
今天在群里无意中看到了这样一个问题,突然发现不会,结果运行一看,懵逼了,不知道为什么???(结果是啥?自己去试试看) 现在我们还是先来复习一下parseInt()这个知识点吧! parseInt() ...
- move_uploaded_file
move_uploaded_file() 函数将上传的文件移动到新位置. 若成功,则返回 true,否则返回 false. 语法 move_uploaded_file(file,newloc) 参数 ...
- 利用PHPExcel导出Excel并设置Excel格式以及数据源
浏览:23969 发布日期:2013/07/24 分类:技术分享 代码有点长,读起来有点累.先来个截图 导出的Excel太宽了,所以将后面的列宽重新调整了再截的图 功能包括: 1.设置单元格格式,包括 ...
- PHP编码规范及建议
<h3 align="center">PHP编码规范及建议</h3>### 编码规范- PHP代码文件必须以 <?php 标签开始.```<?p ...