首页 | 路由技术 | 交换技术 | 接入技术 | 综 合布线 | 网络管理 | 网络安全 | 操作系统 | 实用技巧 | 业界动态
最 新咨询 | 网络编程 | 软件编程 | 脚本技术 | 网页制作 | 网站技巧 | 数据库  | 精品收藏 | 免费资源 | 在线书店
当前位置: 首页 >天空618-IT技术 >网络编程 >Javascript >正文
关键字: 模糊搜索:

JavaScript面向对象编程

发布时间:08-03-02 16:59:16      来源:天空618-IT技术     作者:admin
最新报道

暂时放弃js框架吧开始写javascript的时候都是自己写,后来发现了prototype.js框架,发现很好用,就一直用的,他的对象创建方法被修改了,但很好用,再后来又转用jquery框架,受此框架影响,也不用自己创建类了,渐渐的竟然忘记了如何自己定义类了,猛的给一个一般方法,竟然看着别扭,混淆了很多东西,忘记了很多东西。今天回头整理下。一下方法参考prototype.js
//类的定义
    //方法一:类的一般定义方法
    function player1(_name)
    {
        this.name = _name;
        this.say = function() {alert(this.name);};
    }
    var p1 = new player1('llinzzi1');
    p1.say();
    
    //方法二:prototype定义方法
    var player2 = function() {}
    player2.prototype = {
        name:'',
        say:function(){
            alert(this.name);
        }
    }
    var p2 = new player2();
    p2.name = 'llinzzi2';
    p2.say();
    
    //方法三:上面的方法结构美观,便捷,但构建函数不能带参数,修改方法
    var player3 = function() {
        this.init.apply(this, arguments);
    }
    player3.prototype = {
        init:function(_name){
            this.name = _name;
        },
        say:function(){
            alert(this.name);
        }
    }
    var p3 = new player3('llinzzi3');
    p3.say();
    //类的继承
    //方法一
    var player4 = function(){
        this.init.apply(this, arguments);
    }
    player4.prototype = new player3;
    player4.prototype.shout = function(){
        alert(this.name.toUpperCase());
    }
    var p4 = new player4('llinzzi4');
    p4.shout();
    
    //方法二 上面的方法不能采用{}的方法,修改方法
    Object.extend = function(destination, source) {
      for (var property in source)
        destination[property] = source[property];
      return destination;
    };
    var player5 = function(){
        this.init.apply(this, arguments);
    }
    Object.extend(Object.extend(player5.prototype,player3.prototype),{
        shout:function(){
            alert(this.name.toUpperCase());
        }
    });
    var p5 = new player5('llinzzi5');
    p5.shout();
    
    
    //再从prototype.js抄一端浏览器判断代码
    Browser = {
        IE:     !!(window.attachEvent && !window.opera),
        Opera:  !!window.opera,
        WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1,
        Gecko:  navigator.userAgent.indexOf('Gecko') > -1 && navigator.userAgent.indexOf('KHTML') == -1,
        MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/)
    }
    alert(Browser.MobileSafari);


·上一篇文章:
·下一篇文章:
[ 返回上一页 ]字体[  ] [ 打印 ] [ 发送好友:发送给好友 ][ 加入收藏:加入收藏夹 ]
 
发表评论 ?
  相关文章
相关文章

· 可关闭,最大化,新窗口用层模拟的网页浏览器
· textarea支持图形编辑的实现方法
· 关于javascript参数的问题
· javascript中eval函数的用法与说明
· 完美解决JS中汉字显示乱码问题
· javascript的调试工具下载
· javascript之操作文件(Files)实例说明
· javascript之操作文件(Files)
· javascript之操作文件夹(Folders)
· javascript之操作驱动器(Drives)
最新文章
· 谷歌地图(Google Earth)3D画面下
· 用一根网络线直接连结两台计算机
· 电脑系统进程中文解释大全
· 注册表中显示与隐藏技术应用
· 计算机传染病毒的分类
· 计算机端口入侵大全
· 计算机端口知识详解
· 提供MD5密码破解网站大全
· 上传漏洞页面
· 各网站后台数据库路径
· 搜索引擎使用秘籍
· 机器狗新变种大规模暴发 手工杀毒
· 好游戏下载地址收藏大全
· 液晶显示器面板知识大全
· cpu,主板,显卡等硬件功率速查表(
· 液晶,CRT显示器检测方法
· 内存检测软件大全
· CPU检测工具大全
· 硬件综和性检测分析工具大全
· 可关闭,最大化,新窗口用层模拟的