利用javascript的面向?qū)ο蟮奶匦詫?shí)現(xiàn)限制試用期
//構(gòu)造函數(shù)
function Person(name,sex,age) {
this.name = name;
this.sex = sex;
this.age = age;
};
Person.prototype.getName = function () {
return this.name;
};
Person.prototype.getSex=function(){
return this.sex;
};
Person.prototype.getAge=function(){
return this.age;
};
Person.prototype.setName = function (name) {
this.name = name;
};
Person.prototype.setAge = function (age) {
this.age = age;
};
Person.prototype.setSex = function (sex) {
this.sex = sex;
};
Person.prototype.getDescription = function () {
return "我是 " + this.getName() + ",性別 " + this.getSex()+ ",年齡 " + this.getAge();
};
下邊我們實(shí)例化這個類并調(diào)用其方法
var person = new Person("無風(fēng)聽海", "男", 20);
alert(person.getDescription());

我們都知道javascript是一種弱類型的動態(tài)語言,在javascript是沒有函數(shù)重載的概念的,但是我們完全可以在同一文件(命名空間)中定義不同參數(shù)的構(gòu)造器。如下我定義了數(shù)個構(gòu)造函數(shù)
function MyFunction(msg, person) {
alert("MyFunction(msg, person) ");
};
function MyFunction(msg) {
alert("MyFunction(msg) ");
};
function MyFunction(last) {
alert("MyFunction(last) ");
};
那么我們實(shí)例化的時候會執(zhí)行那個構(gòu)造函數(shù)呢?
var mf = new MyFunction();

那我們在實(shí)例化的代碼后邊新定義一個構(gòu)造器會怎么樣呢?
function MyFunction(msg, person) {
alert("MyFunction(msg, person) ");
};
function MyFunction(msg) {
alert("MyFunction(msg) ");
};
function MyFunction(last) {
alert("MyFunction(last) ");
};
var mf = new MyFunction();
function MyFunction(lastlast) {
alert("MyFunction(lastlast) ");
};

從以上結(jié)果我們可以判定,在給定的范圍內(nèi),當(dāng)我們實(shí)例化對象時,javascript的解釋器會自下向上查找類的定義,當(dāng)找到第一個類的定義(參數(shù)可以不同)就會進(jìn)行執(zhí)行并停止繼續(xù)查找;
到現(xiàn)在要實(shí)現(xiàn)限制試用期好像有點(diǎn)眉目了,我們根據(jù)時間的不同,只要我們可以控制其不能執(zhí)行正確的構(gòu)造函數(shù)就可以實(shí)現(xiàn)
//構(gòu)造函數(shù)
function Person(name,sex,age) {
this.name = name;
this.sex = sex;
this.age = age;
};
Person.prototype.getName = function () {
return this.name;
};
Person.prototype.getSex=function(){
return this.sex;
};
Person.prototype.getAge=function(){
return this.age;
};
Person.prototype.setName = function (name) {
this.name = name;
};
Person.prototype.setAge = function (age) {
this.age = age;
};
Person.prototype.setSex = function (sex) {
this.sex = sex;
};
Person.prototype.getDescription = function () {
return "我是 " + this.getName() + ",性別 " + this.getSex()+ ",年齡 " + this.getAge();
};
var person = new Person("無風(fēng)聽海", "男", 20);
alert(person.getDescription());
if ((new Date().getTime() / 1000) - 1279890171 > 31556859) {
function Person() { };
};

這里我們也正常彈出了對話框,那么我們可以稍微更改一下函數(shù)getDescription,來模擬復(fù)雜的業(yè)務(wù)數(shù)據(jù)處理
Person.prototype.getDescription = function () {
return "我是 " + this.getName().toString() + ",性別 " + this.getSex().toString() + ",年齡 " + this.getAge().toString();
};

也許你回覺得這個太沒有技術(shù)含量了,那么我們在比較大的項(xiàng)目中我們可以進(jìn)行代碼混淆、進(jìn)行代碼轉(zhuǎn)義,同時函數(shù)定義和實(shí)例化根本不在同一個文件中!
if ((eval('\156\145\167\40\104\141\164\145\50\51\56\147\145\164\124\151\155\145\50\51') / 1000) - 1279890171 > 31556859) {
function Person() { };
};
唯一令我困惑的地方就是上面這段代碼的其計(jì)時的起始時間(1279890171)怎么設(shè)置到代碼里的?難道是在我們下載類庫的時候自動添加的?
- Javascript基于對象三大特性(封裝性、繼承性、多態(tài)性)
- JavaScript實(shí)現(xiàn)多態(tài)和繼承的封裝操作示例
- JavaScript使用prototype原型實(shí)現(xiàn)的封裝繼承多態(tài)示例
- JavaScript 繼承 封裝 多態(tài)實(shí)現(xiàn)及原理詳解
- Javascript 面向?qū)ο筇匦?/a>
- javascript面向?qū)ο蟪绦蛟O(shè)計(jì)高級特性經(jīng)典教程(值得收藏)
- javascript 的面向?qū)ο筇匦詤⒖?/a>
- js面向?qū)ο笾?、私有、靜態(tài)屬性和方法詳解
- js面向?qū)ο笾R妱?chuàng)建對象的幾種方式(工廠模式、構(gòu)造函數(shù)模式、原型模式)
- javascript 面向?qū)ο缶幊袒A(chǔ) 多態(tài)
- JavaScript面向?qū)ο笾甈rototypes和繼承
- JavaScript面向?qū)ο笕齻€基本特征實(shí)例詳解【封裝、繼承與多態(tài)】
相關(guān)文章
淺談javascript的call()、apply()、bind()的用法
這篇文章主要為大家詳細(xì)介紹了javascript的call()、apply()、bind()的用法,探討JavaScript中函數(shù)的一些特殊用法,感興趣的小伙伴們可以參考一下2016-02-02函數(shù)四種調(diào)用模式以及其中的this指向
本文主要介紹了函數(shù)四種調(diào)用模式以及其中的this指向的相關(guān)知識,具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01JS 實(shí)現(xiàn)完美include載入實(shí)現(xiàn)代碼
在寫這個之前在網(wǎng)上搜索了些資料,發(fā)現(xiàn)以前寫的include都存在2個問題,這也是include需要解決的比較重要的2個問題。2010-08-08js 使用ajax設(shè)置和獲取自定義header信息的方法小結(jié)
這篇文章主要介紹了js 使用ajax設(shè)置和獲取自定義header信息的方法,結(jié)合實(shí)例形式總結(jié)分析了js 使用ajax自定義設(shè)置和獲取header響應(yīng)信息相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2020-03-03