当前位置:首页 > 芯闻号 > 充电吧
[导读]终于到了说明真正的程序的部分。 作为程序员来讲,似乎只有看到了能动的代码才会安心。但是这里的程序是Javascript,C或者C++程序员看起来会比较陌生。 作者一边查,一边理解,一边尽量详细的说

终于到了说明真正的程序的部分。


作为程序员来讲,似乎只有看到了能动的代码才会安心。但是这里的程序是Javascript,C或者C++程序员看起来会比较陌生。


作者一边查,一边理解,一边尽量详细的说明。如果有说错的地方,敬请指正。


对象字面量表示法


这部分的说明直接引用自【JavaScript高级程序设计,第五章】。


在Javascript中创建Object实例的方式有两种。第一种是使用new操作符后跟Object构造函数,如下所示:


var person = new Object();

persion.name = "Nicholas";

persion.age = 29;


另一种方法是使用对象字面量表示法,对象字面量是对象定义的一种简写形式,目的在于简化创建包含大量属性的对象的过程。下面这个例子就使用了对象字面量语法定义了与前面那个例子中相同的person对象。


var person = {

    name : "Nicholas",

    age : 29

};


第一种C/C++程序员熟悉的方式,而对象字面量表示法就比较陌生了。当然这只是形式上的不同,内容是一样的。稍加适应即可。


代码


//app.js
App({

    onLaunch: function() {
        //调用API从本地缓存中获取数据
        var logs = wx.getStorageSync('logs') || []
        logs.unshift(Date.now())
        wx.setStorageSync('logs', logs)
    },

    getUserInfo: function(cb) {
        var that = this
        if (this.globalData.userInfo) {
            typeof cb == "function" && cb(this.globalData.userInfo)
         } else {
             //调用登录接口
             wx.getUserInfo({
                 withCredentials: false,
                 success: function(res) {
                     that.globalData.userInfo = res.userInfo
                     typeof cb == "function" && cb(that.globalData.userInfo)
                 }
             })
         }
    },
 
    globalData: {
        userInfo: null
    }
})


参数对象


这 段代码的最外层是App()函数,它用来注册小程序。这个函数接受一个 object对象参数,它指定的是小程序的生命周期函数等。这个对象的边界就是App第一个“(”后面的“{”到最后一个小括号前面的“}”。它的内部又 包含了onLaunch函数对象,getUserInfo函数对象和globalData数据对象。


需要注意的是,函数对象也好,数据对象也好,都只是被注册到架构中,至于调用/使用的时机,相信另有安排。


onLauch函数对象


当小程序初始化完成时,会触发 onLaunch(全局只触发一次),在本例中,onLaunch首先从数据缓存中取得logs数组,如果取得失败则通过“|| [ ]“”创建新数组。在数组中增加当前日期(和时间)之后,将数组重新保存在数据缓存中。


程序员不要自己调用这个函数。


getInfo函数对象


如果是第一次调用这个函数则首先调用登录接口取得用户信息,如果不是第一次调用,则直接返回已经取得的用户信息。


取 得用户信息的wx.getUserInfo函数也要稍微说明一下:它是由小程序架构提供的API,仍然是一个对象。这个参数对象又包含了 withCredentials属性和另外的success函数对象。其中success函数会在getUserInfo成功时被调用以接收用户信息。


用C语言的观点来讲,这就是一个回调函数。


globalData数据对象


简单的定义了userinfo数据对象。


参考资料


对象字面量表示法


JavaScript高级程序设计,第五章


微信逻辑层


https://mp.weixin.qq.com/debug/wxadoc/dev/framework/app-service/


小程序API


https://mp.weixin.qq.com/debug/wxadoc/dev/api/


写在文章的最后


既然已经读到这里了,拜托大家再用一分钟时间,将文章转发到各位的朋友圈,微信群中。本公众号的成长需要您的支持! 阅读更多更新文章,请扫描下面二维码,关注微信公众号【面向对象思考】


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭