Heim Web-Frontend js-Tutorial 利用javascript的面向对象的特性实现限制试用期_javascript技巧

利用javascript的面向对象的特性实现限制试用期_javascript技巧

May 16, 2016 pm 06:03 PM
试用期 限制

下边是我自己写的一个类,类中有字段、方法

复制代码 代码如下:

//构造函数
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("无风听海", "男", 20);
alert(person.getDescription());

      我们都知道javascript是一种弱类型的动态语言,在javascript是没有函数重载的概念的,但是我们完全可以在同一文件(命名空间)中定义不同参数的构造器。如下我定义了数个构造函数

复制代码 代码如下:

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(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) ");
};


      从以上结果我们可以判定,在给定的范围内,当我们实例化对象时,javascript的解释器会自下向上查找类的定义,当找到第一个类的定义(参数可以不同)就会进行执行并停止继续查找;
      到现在要实现限制试用期好像有点眉目了,我们根据时间的不同,只要我们可以控制其不能执行正确的构造函数就可以实现
复制代码 代码如下:

//构造函数
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("无风听海", "男", 20);
alert(person.getDescription());
if ((new Date().getTime() / 1000) - 1279890171 > 31556859) {
function Person() { };
};

      这里我们也正常弹出了对话框,那么我们可以稍微更改一下函数getDescription,来模拟复杂的业务数据处理

复制代码 代码如下:

Person.prototype.getDescription = function () {
return "我是 " + this.getName().toString() + ",性别 " + this.getSex().toString() + ",年龄 " + this.getAge().toString();
};


也许你回觉得这个太没有技术含量了,那么我们在比较大的项目中我们可以进行代码混淆、进行代码转义,同时函数定义和实例化根本不在同一个文件中!
复制代码 代码如下:

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() { };
};

唯一令我困惑的地方就是上面这段代码的其计时的起始时间(1279890171)怎么设置到代码里的?难道是在我们下载类库的时候自动添加的?
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie entferne ich Kommentarbeschränkungen für ein Videokonto? Wie hoch ist die Wortbeschränkung für Kommentare zu einem Videokonto? Wie entferne ich Kommentarbeschränkungen für ein Videokonto? Wie hoch ist die Wortbeschränkung für Kommentare zu einem Videokonto? Mar 22, 2024 pm 02:11 PM

Mit der Beliebtheit von Videokonten in sozialen Medien beginnen immer mehr Menschen, Videokonten zu nutzen, um ihr tägliches Leben, ihre Erkenntnisse und Geschichten zu teilen. Bei manchen Benutzern kann es jedoch vorkommen, dass die Kommentare eingeschränkt sind, was zu Verwirrung und Unzufriedenheit führen kann. 1. Wie entferne ich Kommentarbeschränkungen für Videokonten? Um die Einschränkung beim Kommentieren eines Videokontos aufzuheben, müssen Sie zunächst sicherstellen, dass das Konto ordnungsgemäß registriert wurde und die Authentifizierung mit echtem Namen abgeschlossen ist. Für Videokonten gelten Anforderungen für Kommentare. Nur Konten, die die Authentifizierung mit echtem Namen abgeschlossen haben, können Kommentarbeschränkungen aufheben. Wenn es Auffälligkeiten im Konto gibt, müssen diese Probleme behoben werden, bevor die Kommentarbeschränkungen aufgehoben werden können. 2. Halten Sie die Community-Standards des Videokontos ein. Für Videokonten gelten bestimmte Standards für Kommentarinhalte. Wenn der Kommentar illegale Inhalte enthält, wird Ihnen das Sprechen untersagt. Um die Kommentarbeschränkungen aufzuheben, müssen Sie sich an die Community des Videokontos halten

So richten Sie ein CentOS-System ein, um Benutzeränderungen auf Systemprotokolle zu beschränken So richten Sie ein CentOS-System ein, um Benutzeränderungen auf Systemprotokolle zu beschränken Jul 05, 2023 pm 03:43 PM

So richten Sie das CentOS-System ein, um zu verhindern, dass Benutzer das Systemprotokoll ändern. Im CentOS-System ist das Systemprotokoll eine sehr wichtige Informationsquelle. Es zeichnet den Betriebsstatus, Fehlermeldungen, Warnungen usw. auf. Um die Stabilität und Sicherheit des Systems zu schützen, sollten wir Benutzer daran hindern, Systemprotokolle zu ändern. In diesem Artikel wird erläutert, wie Sie das CentOS-System so einrichten, dass die Änderungsberechtigungen des Systemprotokolls eingeschränkt werden. 1. Erstellen Sie Benutzergruppen und Benutzer. Zuerst müssen wir eine Benutzergruppe erstellen, die speziell für die Verwaltung von Systemprotokollen verantwortlich ist, und eine Benutzergruppe für die Verwaltung von Systemprotokollen.

Wie verwende ich JavaScript, um Bilder zu ziehen und zu zoomen und sie gleichzeitig auf den Container zu beschränken? Wie verwende ich JavaScript, um Bilder zu ziehen und zu zoomen und sie gleichzeitig auf den Container zu beschränken? Oct 20, 2023 pm 04:19 PM

Wie implementiert JavaScript das Ziehen und Zoomen von Bildern und beschränkt sie gleichzeitig auf den Container? Bei der Webentwicklung müssen wir häufig Bilder ziehen und zoomen. In diesem Artikel wird erläutert, wie Sie mithilfe von JavaScript das Ziehen und Zoomen von Bildern implementieren und Vorgänge innerhalb des Containers einschränken. 1. Ziehen Sie das Bild. Um das Bild zu ziehen, können wir Mausereignisse verwenden, um die Mausposition zu verfolgen und das Bild entsprechend zu verschieben. Das Folgende ist ein Beispielcode: // Holen Sie sich das Bildelement varimage

Anwendungen und Einschränkungen von Inline-Vorlagenfunktionen Anwendungen und Einschränkungen von Inline-Vorlagenfunktionen Apr 28, 2024 pm 02:33 PM

Inline-Vorlagenfunktionen fügen Code direkt in den Aufrufpunkt ein, ohne ein separates Funktionsobjekt zu generieren. Zu den Anwendungen gehören Codeoptimierung, Leistungsverbesserung, ständige Auswertung und Codevereinfachung. Beachten Sie jedoch die Einschränkungen, z. B. längere Kompilierungszeiten, größere Codegröße, verringerte Debugbarkeit und Einschränkungen bei allen Kompilierungseinheiten.

Was soll ich tun, wenn die maximale Größe der Dokumente, die WPS-Mitglieder hochladen können, das Limit überschreitet? Was soll ich tun, wenn die maximale Größe der Dokumente, die WPS-Mitglieder hochladen können, das Limit überschreitet? Mar 20, 2024 pm 06:40 PM

WPS ist eine Office-Software, die umfassende Funktionen integriert. Sie können WPS jetzt zur Nutzung herunterladen. Wenn Sie jedoch mehr Funktionen nutzen möchten, müssen Sie sich als Mitglied registrieren. Manche Leute fragen sich vielleicht, wie groß die maximale Dateigröße ist, die ein WPS-Mitglied hochladen kann. Wenn Sie ein WPS-Mitglied sind, können Sie jedes Mal Dateien bis zu 1 GB hochladen, und alle Dateien können bis zu 365 GB hochladen. Es kann einige Unterschiede bei verschiedenen Terminals geben, aber die Gesamtanzeige ist grundsätzlich ähnlich. Was soll ich tun, wenn ich nicht über das Limit hinaus hochladen kann? Wir werden es als nächstes erklären. 1. Beim Hochladen von Dateien, z. B. Cloud-Dokumenten, ist ein bestimmter Speicherplatz vorhanden. Wenn dieser den Speicherplatz überschreitet, kann er nicht hochgeladen werden. 2. Klicken Sie auf das Mitgliedschaftslogo, erwerben Sie eine Mitgliedschaft entsprechend Ihren Anforderungen und erweitern Sie den Bereich. 3. Gutscheine können gelegentlich erscheinen, vergessen Sie also nicht, sie zu verwenden.

Welche Einschränkungen und Überlegungen gibt es bei der Überladung von C++-Funktionen? Welche Einschränkungen und Überlegungen gibt es bei der Überladung von C++-Funktionen? Apr 13, 2024 pm 01:09 PM

Zu den Einschränkungen bei der Funktionsüberladung gehören: Parametertypen und -reihenfolgen müssen unterschiedlich sein (wenn die Anzahl der Parameter gleich ist), und Standardparameter können nicht zur Unterscheidung von Überladungen verwendet werden. Darüber hinaus können Vorlagenfunktionen und Nicht-Vorlagenfunktionen nicht überladen werden, und Vorlagenfunktionen mit unterschiedlichen Vorlagenspezifikationen können überlastet werden. Es ist erwähnenswert, dass eine übermäßige Funktionsüberladung die Lesbarkeit und das Debuggen beeinträchtigen kann, da der Compiler von der spezifischsten zur unspezifischsten Funktion sucht, um Konflikte zu lösen.

Vorteile und Grenzen des MyBatis Reverse Engineering Vorteile und Grenzen des MyBatis Reverse Engineering Feb 22, 2024 pm 07:27 PM

MyBatis ist ein beliebtes Persistenz-Framework, das Reverse-Engineering-Funktionen bereitstellt, mit denen Entwickler automatisch Entitätsklassen, Mapper-Schnittstellen und XML-Zuordnungsdateien basierend auf der Tabellenstruktur in der Datenbank generieren können. Reverse Engineering ist eine wichtige Funktion von MyBatis, die die Arbeitsbelastung des Entwicklers erheblich reduzieren und die Wartbarkeit des Codes verbessern kann. Allerdings weist Reverse Engineering auch einige Einschränkungen auf. In diesem Artikel werden die Vorteile und Einschränkungen von MyBatis Reverse Engineering vorgestellt und anhand konkreter Codebeispiele veranschaulicht. Lassen Sie uns zunächst einmal

Verwenden Sie jQuery, um ein Eingabefeld zu implementieren, das nur die Eingabe von Zahlen und Dezimalstellen zulässt Verwenden Sie jQuery, um ein Eingabefeld zu implementieren, das nur die Eingabe von Zahlen und Dezimalstellen zulässt Feb 26, 2024 am 11:21 AM

Implementieren Sie ein jQuery-Eingabefeld, um die Eingabe von Zahlen und Dezimalstellen einzuschränken. Bei der Webentwicklung müssen wir häufig die Eingabe von Inhalten durch Benutzer in das Eingabefeld beschränken, indem wir beispielsweise die Eingabe nur von Zahlen und Dezimalstellen beschränken. Diese Einschränkung kann durch JavaScript und jQuery erreicht werden. Im Folgenden wird erläutert, wie Sie mit jQuery die Funktion zur Begrenzung der Eingabe von Zahlen und Dezimalstellen in das Eingabefeld implementieren. 1. HTML-Struktur Zuerst müssen wir ein Eingabefeld in HTML erstellen. Der Code lautet wie folgt:

See all articles