js初始化验证实例详解


Posted in Javascript onNovember 26, 2016

本文实例讲述了js初始化验证的方法。分享给大家供大家参考,具体如下:

<script type="text/javascript">
var Book = function(isbn, title, author) {
 if(!this.checkIsbn(isbn)){
   throw new Error('Book: Invalid ISBN.');
 } 
 this.isbn = isbn;
 this.title = title || 'No title specified';
 this.author = author || 'No author specified';
}
Book.prototype = {
 checkIsbn: function(isbn) {
  if(isbn == undefined || typeof isbn != 'string') {
   return false;
  }
  return true; // All tests passed.
 },
 display: function() {
  alert("isbn:"+this.isbn+" title:"+this.title+" author:"+this.author);
 }
};
var theHobbit = new Book('0-395-07122-4', 'The Hobbit', 'J. R. R. Tolkein');
theHobbit.display(); // Outputs the data by creating and populating an HTML element.
</script>

对isbn进行验证。是否定义,是否为字符串等等。对title进行判断,设置默认。

另一种实现方式

<script type="text/javascript">
/* 出版 interface. */
/* var Publication = new Interface('Publication', ['getIsbn', 'setIsbn', 'getTitle',
 'setTitle', 'getAuthor', 'setAuthor', 'display']); */
var Book = function(isbn, title, author) { // implements Publication
 this.setIsbn(isbn);
 this.setTitle(title);
 this.setAuthor(author);
}
Book.prototype = {
 checkIsbn: function(isbn) {
  if(isbn == undefined || typeof isbn != 'string') {
   return false;
  }
  return true; // All tests passed.
 },
 getIsbn: function() {
  return this.isbn;
 },
 setIsbn: function(isbn) {
  if(!this.checkIsbn(isbn)) throw new Error('Book: Invalid ISBN.');
  this.isbn = isbn;
 },
 getTitle: function() {
  return this.title;
 },
 setTitle: function(title) {
  this.title = title || 'No title specified';
 },
 getAuthor: function() {
  return this.author;
 },
 setAuthor: function(author) {
  this.author = author || 'No author specified';
 },
 display: function() {
  alert("isbn:"+this.isbn+" title:"+this.title+" author:"+this.author);
 }
};
var theHobbit = new Book('0-395-07122-4', '', 'J. R. R. Tolkein');
theHobbit.display(); // Outputs the data by creating and populating an HTML element.
</script>

接口实现,参考接口,定义了好多方法。

内部方法命名加_,例如这个检测的方法 _checkIsbn

<script type="text/javascript">
/* 出版 interface. */
/* var Publication = new Interface('Publication', ['getIsbn', 'setIsbn', 'getTitle',
 'setTitle', 'getAuthor', 'setAuthor', 'display']); */
var Book = function(isbn, title, author) { // implements Publication
 this.setIsbn(isbn);
 this.setTitle(title);
 this.setAuthor(author);
}
Book.prototype = {
 _checkIsbn: function(isbn) {
  if(isbn == undefined || typeof isbn != 'string') {
   return false;
  }
  return true; // All tests passed.
 },
 getIsbn: function() {
  return this.isbn;
 },
 setIsbn: function(isbn) {
  if(!this._checkIsbn(isbn)) throw new Error('Book: Invalid ISBN.');
  this.isbn = isbn;
 },
 getTitle: function() {
  return this.title;
 },
 setTitle: function(title) {
  this.title = title || 'No title specified';
 },
 getAuthor: function() {
  return this.author;
 },
 setAuthor: function(author) {
  this.author = author || 'No author specified';
 },
 display: function() {
  alert("isbn:"+this.isbn+" title:"+this.title+" author:"+this.author);
 }
};
//var theHobbit = new Book(123, '', 'J. R. R. Tolkein'); // 非字符串抛出异常
var theHobbit = new Book('1990-78sd-1092', '', 'J. R. R. Tolkein'); 
theHobbit.display(); // Outputs the data by creating and populating an HTML element.
</script>

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
javascript中的几个运算符
Jun 29 Javascript
对xmlHttp对象方法和属性的理解
Jan 17 Javascript
Jquery右下角抖动、浮动 实例代码(兼容ie6、FF)
Aug 15 Javascript
实例说明为什么不要行内使用javascript
Apr 18 Javascript
jQuery EasyUI中DataGird动态生成列的方法
Apr 05 Javascript
iframe中使用jquery进行查找的方法【案例分析】
Jun 17 Javascript
js 创建对象 经典模式全面了解
Aug 16 Javascript
理解 javascript 中的函数表达式与函数声明
Jul 07 Javascript
vue中使用element-ui进行表单验证的实例代码
Jun 22 Javascript
详解Angular Karma测试的持续集成实践
Nov 15 Javascript
JS变量提升原理与用法实例浅析
May 22 Javascript
TypeScript中条件类型精读与实践记录
Oct 05 Javascript
浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
Nov 26 #Javascript
JS匿名函数实例分析
Nov 26 #Javascript
利用Js的console对象,在控制台打印调式信息测试Js的实现
Nov 26 #Javascript
JS类的定义与使用方法深入探索
Nov 26 #Javascript
js控制台输出的方法(详解)
Nov 26 #Javascript
jQuery基于排序功能实现上移、下移的方法
Nov 26 #Javascript
node.js中的事件处理机制详解
Nov 26 #Javascript
You might like
php adodb操作mysql数据库
2009/03/19 PHP
一步一步学习PHP(2)――PHP类型
2010/02/15 PHP
php读取文件内容的几种方法详解
2013/06/26 PHP
使用Thinkphp框架开发移动端接口
2015/08/05 PHP
php 替换文章中的图片路径,下载图片到本地服务器的方法
2018/02/06 PHP
解决Extjs 4 Panel作为Window组件的子组件时出现双重边框问题
2013/01/11 Javascript
JavaScript中split() 使用方法汇总
2015/04/17 Javascript
bootstrap实现图片自动轮播
2016/12/21 Javascript
利用js判断手机是否安装某个app的多种方案
2017/02/13 Javascript
electron demo项目npm install安装失败的解决方法
2018/02/06 Javascript
vue展示dicom文件医疗系统的实现代码
2018/08/27 Javascript
解决Vue2.0 watch对象属性变化监听不到的问题
2018/09/11 Javascript
angular 实现同步验证器跨字段验证的方法
2019/04/11 Javascript
在Linux下使用Python的matplotlib绘制数据图的教程
2015/06/11 Python
Python使用Selenium模块模拟浏览器抓取斗鱼直播间信息示例
2018/07/18 Python
对numpy中的where方法嵌套使用详解
2018/10/31 Python
Python中求对数方法总结
2020/03/10 Python
Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法
2020/03/20 Python
Python3自定义http/https请求拦截mitmproxy脚本实例
2020/05/11 Python
django 连接数据库出现1045错误的解决方式
2020/05/14 Python
Python连接Mysql进行增删改查的示例代码
2020/08/03 Python
python使用bs4爬取boss直聘静态页面
2020/10/10 Python
用python获取txt文件中关键字的数量
2020/12/24 Python
美国最受欢迎的童装品牌之一:The Children’s Place
2016/07/23 全球购物
美国最大的船只买卖在线市场:Boat Trader
2018/08/04 全球购物
JYSK加拿大:购买家具、床垫、家居装饰等
2020/02/14 全球购物
幼儿园长自我鉴定
2013/10/17 职场文书
厨房工作人员岗位职责
2013/11/15 职场文书
教师岗位职责
2013/11/17 职场文书
写给女朋友的道歉信
2014/01/12 职场文书
妇女干部培训方案
2014/05/12 职场文书
新疆民族团结演讲稿
2014/08/27 职场文书
语文教师个人工作总结
2015/02/06 职场文书
通讯稿格式及范文
2015/07/22 职场文书
2016年元旦寄语
2015/08/17 职场文书
详解CSS故障艺术
2021/05/25 HTML / CSS