JavaScript高級プログラム設計_1~6章の練習
19572 ワード
この本の第六章を読み終わったばかりです.気持ちがいいです.私にとって、この本は小説を読むよりいい感じです.
//2013-8-4 18:17:03
//1,factory model
//function createPerson(name, age) {
// var o = new Object();
// o.name = name;
// o.age = age;
// o.sayName = function() {
// alert(this.name);
// };
// return o;
//}
//
//var person1 = createPerson('vivi', '23');
//var person2 = createPerson('ali', '22');
// person1.sayName();
// 2,constructor model
//function Person(name, age) {
// this.name = name;
// this.age = age;
// this.sayName = function() {
// alert(this.name);
// };
//}
//var person1 = new Person('vivi', '23');
// person1.sayName();
// alert(person1.constructor);
// alert(person1.constructor==Person);
//var x = 'x';
// alert(x.constructor);
// alert(person1 instanceof Person);
// alert(person1 instanceof Object);
// alert(x instanceof Person);
// alert(x instanceof Object);
// alert(x instanceof String);
// alert(x.constructor==String);
//var personCreate = createPerson('vivi', '23');
// alert(personCreate.constructor);
//var personCreate2 = new createPerson('vivi', '23');
// alert(personCreate2.constructor);
// alert(personCreate instanceof createPerson);
// alert(personCreate2 instanceof createPerson);
//var p1 = new Person();
//var p2 = new createPerson();
// alert(p1 instanceof Person);
// alert(p2 instanceof createPerson);
//Person('vivi', '23');
// window.sayName();
// sum(1, 3);
//function sum(num1, num2) {
// alert(num1+num2);
//}
//
// 5.5.3
//function callSomeFunction(someFunction, someArguments) {
// return someFunction(someArguments);
//}
//function add3(num) {
// return num + 3;
//}
//function getGreeting(name) {
// return 'hello,' + name;
//}
//var result1 = callSomeFunction(add3, 33);
// alert(result1);
//var result2 = callSomeFunction(getGreeting, 'vivi');
// alert(result2);
//
//function createComparisonFunction(propertyName) {
// return function(object1, object2) {
// var value1 = object1[propertyName];
// var value2 = object2[propertyName];
// if (value1 < value2) {
// return -1;
// } else if (value1 > value2) {
// return 1;
// } else {
// return 0;
// }
// };
//}
//
//var data=[{name:'zhangbin',age:2},{name:'vikram',age:11}];
//data.sort(createComparisonFunction('name'));
// alert(data[0].name);
//data.sort(createComparisonFunction('age'));
// alert(data[0].name);
//
//
//
//var message = 'vivi';
// a(message);
// a(typeof message);
// a(typeof typeof message);
// a(typeof 99);
// a(typeof typeof 99);
// a(typeof null);
// c(typeof undefined);
// c(typeof null);
// c(typeof c);
// c(typeof 'vivi');
// c(typeof 2);
// c(typeof person1);
// c(person1 instanceof Person);
// c(typeof true);
// c(2 instanceof Number);
// c(typeof '2');
// c(null == undefined);c(typeof NaN);
// c(Number.NEGATIVE_INFINITY);
// c(Number.POSITIVE_INFINITY);
// c(Number.MAX_VALUE);
// c(isNaN(2));
// c(isNaN(false));
//var num = 1024234523432234321234;
// c(num.toString(2));
// c(num.toString(3));
// c(num.toString(5));
// c(num.toString(36));
// for(var name in window){
// document.writeln(name);
// }
// for(var name in person1){
// c(name);
// }
//function sayHi(){
// c('hello,'+arguments[0]+','+arguments[2]);
// arguments[3] = '2';
// c(arguments.length);
//}
// sayHi('vivi');
//function doAdd(num1,num2){
// arguments[1]=100;
// c(arguments[0]+num2);
//}
// doAdd(3,4);
//var colors = ['red','black','blue'];
// c(colors.length);
// colors[99]='brown';
// c(colors.length);
// c(colors[55]);
// c(colors instanceof Object);
// c(colors instanceof Array);
// c(typeof colors);
// c(colors instanceof String);
// c(Array.isArray(colors));
// c(colors);
// colors.toString();
// c(colors);
// c(colors.toLocaleString());
// c(colors.join('*'));
// var colors = new Array();
// var count = colors.push('red','black');
// var count = colors.push('green');
// var item = colors.pop();
// c(item);
// c(count);c(colors);
// c(colors.length);
// var item = colors.shift();
// c(item);c(colors.length);
// var values = [1,5,10,15];
// c(values.sort());
// c(values.sort(function(){
//
// }));
//var colors = ['red','black','white'];
// var colors2 = colors.concat('pink');
// c(colors2);
// var colors3 = colors2;
// colors3.pop();
// c(colors3);
// c(colors2);
// c(colors);
//var removed = colors.splice(0, 1);
// c(removed);
// c(colors);
//removed = colors.splice(2, 0, 'yellow','orange');
// c(removed);
// c(colors);
//removed=colors.splice(2, 2, 'red','purple');
// c(colors);
// c(removed);
// c(colors);
// 2013-8-4 18:17:03
// var numbers = new Array();
// numbers = [1,2,3,4,5,4,3,2,1];
// c(numbers.indexOf(2));
//var numbers=[1,2,3,4,5,4,3,2,1];
// c(numbers.indexOf(8));
// c(numbers.indexOf(4,4));
//var person = {'name':'vivi'};
//var people=[{'name':'vivi'}];
//var morePeople = [person];
// c(morePeople);
// c(people.indexOf(person));
// c(morePeople.indexOf(person));
// c(people instanceof Array);
//var everyResult=numbers.every(function (item,index,array){
// c(arguments[0]);
// c(arguments[1]);
// c(arguments[2]);
// c(arguments[3]);
// c('-----');
// return (item>2);
// return (item*2);
//});
// c(everyResult);
//var someResult=numbers.some(function(item,index,array){
// return item > 2;
//});
// c(someResult);
//var filterResult = numbers.filter(function(item,index,array){
// return item > 2;
//});
// c(filterResult);
//var mapResult=numbers.map(function(item,index,array){
// return item*2;
// return item >2;
//});
// c(mapResult);
//
//var forEachResult=numbers.forEach(function(item,index,array){
// return c(item);
//});
// c(forEachResult);
// var values=[1,2,3,4,5];
//var values=[1];
// var sum=values.reduce(function(prev,cur,index,array){
// a('in reduce');
// c(prev + ',' + cur);
// return prev + cur;
// });
// c(sum);
//var now = new Date();
// c(now);
// c(now.toString());
// c(now.toDateString());
// c(now.toLocaleDateString());
// c(now.toLocaleString());
// c(now.toTimeString());
// c(now.toUTCString());
// for(var name in now){
// c(name);
// }
// c(now instanceof Date);
// for(var name in Date){
// c(name);
// }
// var t = new Date(Date.parse('222'));
//var t = new Date(3002);
// c(t.toLocaleString());
//var pattern2 = new RegExp('[bc]at','i');
// c(pattern2.global);
// c(pattern2.ignoreCase);
//var text = 'mom and dad and baby';
//var pattern=/mom( and dad( and baby)?)?/gi;
// c(pattern instanceof RegExp);
//var matches=pattern.exec(text);
// c(matches);
//var text = 'cat,bat,sat,fat,lat,dat,sat';
//var pattern1=/.at/;
// var matches=pattern1.exec(text);
// c(matches);
// c(pattern1.lastIndex);
//var pattern2=/.at/g;
// var matches=pattern2.exec(text);
// c(matches);
// matches=pattern2.exec(text);
// c(matches);
// var matches2 = ['ds'];
// while(pattern2.test(text)){
// c(pattern2.lastIndex);
// var x = pattern2.exec(text);
// c('x:' + x);
// matches2.push(x[0]);
// matches2.push('red');
// c(matches2);
// }
// c(matches2);
// 2013 8 4 22:30:30
// function factorial(num){
// c(arguments.callee);
// c('num:'+num);
// if(num<1){
// return 1;
// }else{
// return num*factorial(num-1);
// }
// }
// var num = factorial(5);
//function factorial(num){
// c(arguments.callee);
// if(num<1){
// return 1;
// }else{
// return num* arguments.callee(num-1);
// }
//}
// var num = factorial(5);
// var trueFactorial=factorial;
// var num=trueFactorial(5);
//function outer(){
// inner();
// c(outer.caller);
//}
//function inner(){
// c(inner.caller);
// c(arguments.callee.caller);
//}
// outer();
// c(outer.caller);
//
//function sum(num1,num2){
// return num1 + num2;
//}
//function callSum1(num1,num2){
// c(this.text);
// c(this);
// c(arguments);
// return sum.apply(this,[num1,num2]);
//}
// c(callSum1(10,22));
//function callSum2(num1,num2){
// this.name='haha';
// var aa = callSum1(22,33);
//}
// callSum2();
// c(aa);
// c(name);
//window.color='red';
//var o={color:'blue'};
//function sayColor(){
// c(this);
// c(this.color);
//}
// sayColor();
// sayColor.call(this);
// sayColor.call(window);
// sayColor.call(o);
// c.sayColor();
//var objectSayColor=sayColor.bind(o);
// c(objectSayColor);
// objectSayColor();
// for(var name in Global){
// c(name);
// }
//var uri='a b c ';
// c(encodeURI(uri));
//var msg = 'hello world';
// eval('c(msg)');
//var person = {};
//Object.defineProperty(person,'name',{
// writable:false,
// value:'vivi'
//});
// c(person.name);
//person.name='ali';
// c(person.name);
//var person={
// name:'kakui'
//};
// c(person.name);
// 2013-8-6 22:24:48
//var book = {
// _year :2004,
// edition:1
//};
//
//Object.defineProperty(book,'year',{
// get:function(){
// a('get function run.');
// return this._year;
// },
// set:function(newValue){
// a('set function run.');
// if(newValue > 2004){
// this._year = newValue;
// this.edition += newValue - 2004;
// }
// }
//});
//
// book.year = 2005;
// alert(book.edition);
// alert('book.getYear:' + book.year);
//
//var book = {};
//
//Object.defineProperties(book,{
// _year : {
// value : 2004
// },
//
// edition : {
// value : 1
// },
//
// year : {
// get : function(){
// return this._year;
// },
// set : function(newValue){
// if(newValue > 2004){
// this._year = newValue;
// this.edition = newValue-2004;
// }
// }
// }
//});
//
//var descriptor = Object.getOwnPropertyDescriptor(book,'_year');
// for(var name in descriptor){
// c(name + ':'+descriptor[name]);
// }
//
//var person1 = new Person('vivi',22);
// c(person1.constructor);
// a(person1.constructor);
//
//var person2 = new Person('vivivivi',22);
// c(person2 instanceof Person);
// c(person1 instanceof Person);
// c(person2.sayName());
// c(window.sayName());
//
//function Person(){
// this.other = 'other';
// this.sayOther = function(){
// alert(this.other);
// };
//}
//
// a(Person.prototype);
// c(Person.prototype);
//
//Person.prototype.name = 'vivi';
//Person.prototype.age = 22;
//Person.prototype.sayName = function(){
// alert(this.name);
//};
//Person.prototype.sayOther = function(){
// alert('othor function in proto');
//};
//
// a(Person.prototype);
// c(Person.prototype);
//
//var person1 = new Person();
//var person2 = new Person();
// c(person1.name);
// c(person2.name);
// c(person1.sayName == person2.sayName);
// c(person1.other == person2.other);
// c(person1.sayOther == person2.sayOther);
// a(person1.constructor);
// a(Person.constructor);
// c(person1.constructor == Person.constructor);
// c(person1.constructor);
// c(Person.constructor);
// a(Person.prototype);
// c(person1.__proto__);
// c(Person.prototype.constructor == person1.constructor);
// c(Person == Person.prototype.constructor);
// c(Person.prototype.isPrototypeOf(person1));
// c(name.isPrototypeOf(person1));
// c(Object.getPrototypeOf(person1));
// person1.sayOther();
//
// 2013-8-7 22:56:57
//function Person(){}
//Person.prototype.name = 'vivi';
//Person.prototype.age = 22;
//Person.prototype.sayName = function(){alert(this.name);};
//
//var person1 = new Person();
//var person2 = new Person();
//
// c(person1.hasOwnProperty('name'));
//person1.name='ali';
// c(person1.hasOwnProperty('name'));
// delete person1.name;
// c(person1.name);
// c(person1.hasOwnProperty('name'));
// c(Object.getOwnPropertyDescriptor(person1,'age'));
// c('name' in person1);
//function hasPrototypeProperty(object,name){
// return !object.hasOwnProperty(name)&&(name in object);
//}
//var keys = Object.keys(Person.prototype);
// c(keys);
//keys = Object.keys(person1);
// c(keys);
//keys = Object.keys(person1.constructor);
// c(keys);
// c(Person.prototype instanceof Object);
//var keys = Object.getOwnPropertyNames(Person.prototype);
// c(keys);
//
//function Person(){}
//Person.prototype = {
// name:'vivi',
// age:22,
// sayName : function(){
// alert(this.name);
// }
//};
// a(Person.prototype.constructor);
//var friend = new Person();
// c(friend instanceof Person);
//var friend2 = Person();
// c(friend2 instanceof Person);
// c(friend2 instanceof Object);
// c(friend2);
//Object.defineProperty(Person.prototype,'constructor',{
// enumerable :false,
// value : Person
//});
//
//function Person2(){}
//var friend = new Person2();
//Person2.prototype = {
// construtor : Person,
// name:'vivi',
// age:22,
// sayName : function(){
// alert(this.name);
// }
//};
//
// friend.sayName();
// c(friend.name);
//var keys = Object.keys(Object.prototype);
// c(keys);
//keys = Object.keys(Array.prototype);
// c(keys);
// c(typeof Array.prototype.sort);
//keys = Object.getOwnPropertyNames(Object.prototype);
// c(keys);
//keys = Object.getOwnPropertyNames(person1);
// c(keys);
// c(person1.__proto__);
//
//String.prototype.startsWith = function(text){
// return this.indexOf(text) == 0;
//};
//
//var msg = 'Hello World!';
// c(msg.startsWith('hello'));
//function Person(){}
//
//Person.prototype = {
// name:'vivi',
// age:22,
// friends:['jl','ali'],
// sayName : function(){
// alert(this.name);
// }
//};
//
//var person1 = new Person();
//var person2 = new Person();
//person1.friends.push('xj');
// c(person2.friends);
//
//function Person(name,age){
// this.name = name;
// this.age = age;
// this.friends = ['ali','xiaoxi'];
//}
//
//Person.prototype = {
// constructor : Person,
// sayName : function(){
// alert(this.name);
// }
//};
//
//function Person(name,age){
// this.name = name;
// this.age = age;
// if(typeof sayName != 'function'){
// Person.prototype.sayName = function(){
// alert(this.name);
// };
// }
//}
//
//2013-8-8 22:42:38
//function SpecialArray(){
// var values = new Array();
// values.push.apply(values,arguments);
// values.push(arguments[0],arguments[1]);
// values.toPipedString = function(){
// return this.join('|');
// };
// return values;
//}
//
//var colors = new SpecialArray('red','blue','black');
// c(colors);
//c(colors.toPipedString());
//var time = new Date();
// for(var prop in Object.getOwnPropertyNames(time)){
// c(prop);
// }
//
//function SuperType(){
// this.property = true;
//}
//
//SuperType.prototype.getSuperValue = function(){
// return this.property;
//};
//
//function SubType(){
// this.subproperty = false;
//}
//
//SubType.prototype = new SuperType();
//SubType.prototype.getSubValue = function(){
// return this.subproperty;
//};
//
//var instance = new SubType();
//c(instance.getSuperValue());
//c(instance.constructor);
//
//c(instance.__proto__.constructor);
//c(instance instanceof SubType);
//
//c(Object.prototype.isPrototypeOf(instance));
//c(SuperType.prototype.isPrototypeOf(instance));
//c(SubType.prototype.isPrototypeOf(instance));
//
//function SuperType(){
// this.property = true;
//}
//
//SuperType.prototype.getSuperType = function(){
// return this.property;
//};
//
//function SubType(){
// this.subproperty = false;
//}
//
//SubType.prototype = new SuperType();
//
//SubType.prototype.getSubValue = function(){
// return this.subproperty;
//};
//
//SubType.prototype.getSuperValue = function(){
// return false;
//};
//
//var instance = new SubType();
//c(instance.getSuperValue());
//
//function SuperType(){
// this.property = true;
//}
//
//SuperType.prototype.getSuperValue = function(){
// return this.property;
//}
//
//function SubType(){
// this.subproperty = false;
//}
//
//SubType.prototype.getSubValue = function(){
// return this.subproperty;
//};
//
//SubType.prototype = {
// getValues : function(){
//
// }
//};
//
//c(SubType.prototype);
//
//
//var instance = new SubType();
//c(SubType instanceof Function);
//c(SubType.hasOwnProperty('prototype'));
//c(instance.hasOwnProperty('prototype'));
//c(instance.hasOwnProperty('__proto__'));
//c(instance.__proto__);
//
//function SuperType(){
// this.colors = ['red','green','black'];
//}
//
//function SubType(){}
//
//SubType.prototype = new SuperType();
//
//var instance1 = new SubType();
//instance1.colors.push('grey');
//c(instance1.colors);
//var instance2 = new SubType();
//c(instance2.colors);
//var instance3 = new SuperType();
//c(instance3.colors);
//
//function SuperType() {
// this.colors = [ 'red', 'black' ];
//}
//
//function SubType() {
// SuperType.call(this);
//}
//
//var instance1 = new SubType();
//instance1.colors.push('green');
//c(instance1.colors);
//var instance2 = new SubType();
//c(instance2.colors);
//c(instance1.__proto__);
//c(instance1.constructor);
//
//function SuperType(name){
// this.name = name;
//}
//
//function SubType(name){
// SuperType.call(this, arguments);
//}
//
//var instance1 = new SubType('vivi');
//c(instance1.name);
//function SuperType(name) {
// this.name = name;
// this.colors = [ 'red', 'black' ];
//}
//
//SuperType.prototype.sayName = function() {
// alert(this.name);
//};
//
//function SubType(name, age) {
// SuperType.call(this, name);
// this.age = age;
//}
//
//SubType.prototype = new SuperType();
//SubType.prototype.sayAge = function(){
// alert(this.age);
//};
//
//var instance1 = new SubType('vivi',22);
//instance1.colors.push('green');
//c(instance1.colors);
//instance1.sayName();
//instance1.sayAge();
//var instance2 = new SubType('ali',23);
//c(instance2.colors);
//instance2.sayName();
//instance2k.sayAge();
function object(o){
function F(){}
F.prototype = o;
return new F();
}
var person = {
name:'vivi',
friends:['ali','aming']
};
//
//c(person.frends);
//var anotherPerson = object(person);
//anotherPerson.name = 'xiaoxi';
//anotherPerson.frends = [];
//anotherPerson.frends.push('xiaozhen');
//var yetAnotherPerson = object(person);
//yetAnotherPerson.name='jiuli';
//yetAnotherPerson.frends.push('ahui');
//c(person.frends);
//c(anotherPerson.frends);
//c(yetAnotherPerson.frends);
//c(person.name);
//c(anotherPerson.name);
//c(anotherPerson.__proto__.frends == person.frends);
//
//var anotherPerson = Object.create(person);
//anotherPerson.name = 'xiaozhen';
//anotherPerson.friends.push('xiaoxi');
//c(person.friends);
//c(person.name);
function createAnother(original){
var clone = object(original);
clone.sayHi=function(){
alert('hi');
};
return clone;
}
function inheritPrototype(subType,superType){
var prototype = superType.prototype;
subType.prototype = prototype;
subType.constructor = subType;
}
function SuperType(name){
this.name = name;
this.colors = ['red','black'];
}
SuperType.prototype.sayName = function(){
alert(this.name);
};
function SubType(name,age){
SuperType.call(this,name);
this.age = age;
}
inheritPrototype(SubType, SuperType);
SubType.prototype.sayAge = function(){
alert(this.age);
};
var instance1 = new SubType();
instance1.colors.push('green');
c(instance1.colors);
var instance2 = new SuperType();
c(instance2.colors);