基于Node.js和Cocos Creator的開發(fā) 【一溜徙,實(shí)現(xiàn)http通信】

一晴圾,開發(fā)環(huán)境及前言

本示例開發(fā)環(huán)境如下:

  • macOS High Sierra 版本10.13.4

  • nodejs v10.6.0

  • Cocos Creator V2.0

  • Code V1.25.1

JavaScript最初只能用于網(wǎng)頁的前端開發(fā)穷劈,Node.js推出之后夸浅,JavaScript可以進(jìn)行后端開發(fā)了趁桃,cocos2d-js辽话、Cocos Creator、微信小程序使得JavaScript能夠直接進(jìn)行游戲開發(fā)卫病,Electron可以方便的把JavaScript開發(fā)的應(yīng)用發(fā)布成跨平臺(tái)的桌面應(yīng)用油啤,開源庫(kù)TensorFlow.js更是將JS擴(kuò)展到熱門的機(jī)器學(xué)習(xí)領(lǐng)域。
JavaScript的引用領(lǐng)域原來越廣泛了蟀苛,大有一統(tǒng)江湖之勢(shì):

  • 網(wǎng)頁開發(fā)
  • 服務(wù)器開發(fā)
  • 手游開發(fā)
  • 桌面應(yīng)用
  • 機(jī)器學(xué)習(xí)領(lǐng)域

在功能機(jī)時(shí)代益咬,缺少游戲引擎的支持,UI使用硬編碼方式進(jìn)行部署帜平,在產(chǎn)品改變UI幽告、調(diào)整數(shù)值時(shí)都要重新編碼梅鹦,只有打包放到手機(jī)上才能看到產(chǎn)品效果。這些工作都需要程序員來操作冗锁。Cocos Creator是以內(nèi)容創(chuàng)作為核心的游戲開發(fā)工具齐唆,其包含游戲引擎、資源管理冻河、場(chǎng)景編輯箍邮、游戲預(yù)覽和發(fā)布等游戲開發(fā)所需的全套功能,并且將所有的功能和工具鏈都整合于一體芋绸,為美術(shù)和策劃人員提供前所未有的內(nèi)容創(chuàng)作生產(chǎn)和即時(shí)預(yù)覽測(cè)試環(huán)境媒殉。以工作流為核心的開發(fā)理念,讓不同職能的開發(fā)者能夠快速找到最大化自己作用的工作切入點(diǎn)摔敛,并能夠默契流暢的和團(tuán)隊(duì)其他成員配合廷蓉。

二,使用node.js創(chuàng)建http服務(wù)

node.js使用Code工具開發(fā)马昙,新建一個(gè)文件夾:Server桃犬,導(dǎo)入到Code開發(fā)環(huán)境中。
在Server工程目錄下新建httpServer.js行楞,寫入以下代碼:

const http = require('http');
http.createServer(function(req, res) {
        var response = 'Hello World';
        res.write(response);
        res.end();
}).listen(8181);

第一行代碼引入需要的模塊攒暇,第三代碼使用http模塊提供的接口建立一個(gè)監(jiān)聽8181端口的http服務(wù)。
從命令行啟動(dòng)服務(wù):
node httpServer.js
在瀏覽器中輸入http://127.0.0.1:8181子房,我們就可以看到這個(gè)畫面了:

01.png

三形用,手機(jī)端http訪問實(shí)現(xiàn)

使用Cocos Creator新建一個(gè)項(xiàng)目,組織目錄結(jié)構(gòu)证杭,示例如下:

02.png

http請(qǐng)求接口的實(shí)現(xiàn)

Cocos Creator支持Web平臺(tái)上最廣泛使用的標(biāo)準(zhǔn)網(wǎng)絡(luò)接口:

  • XMLHttpRequest:用于短連接
  • WebSocket:用于長(zhǎng)連接
    我們使用XMLHttpRequest實(shí)現(xiàn)手機(jī)端的http服務(wù)請(qǐng)求田度,在http.js文件中寫下如下代碼:
module.exports = {
    request: function(obj) {
        var httpRequest = new XMLHttpRequest();
        var time = 5*1000;
        var timeout = false;

        // 超時(shí)設(shè)置
        var timer = setTimeout(function(){
            timeout = true;
            httpRequest.abort();
        }, time);

        var url = obj.url;

        // 組織請(qǐng)求參數(shù)
        if (typeof obj.data == 'object') {
            console.info('obj.data=' + JSON.stringify(obj.data));
            var kvs = []
            for (var k in obj.data) {
               kvs.push(encodeURIComponent(k) + '=' + encodeURIComponent(obj.data[k]));
            }
            url += '?';
            url += kvs.join('&');
        }

        httpRequest.open(obj.method?obj.method:'GET', url, true);
        
        httpRequest.onreadystatechange = function () {
            var response = httpRequest.responseText;
            console.info('http url cb:' +  url + ' readyState:' + httpRequest.readyState + ' status:' + httpRequest.status);
            clearTimeout(timer);

            if (httpRequest.readyState == 4) {
                console.info('http success:' + url + ' resp:' + response);
                if (typeof obj.success == 'function') {
                    obj.success(response);
                }
            } else {
                console.info('http fail:' + url);
                if (typeof obj.fail == 'function') {
                    obj.fail(response);
                }
            }
        };
        httpRequest.send();
    }
}

參數(shù)說明:obj為一個(gè)JSON結(jié)構(gòu)體,需要包含url鍵解愤,data做為可選鍵镇饺,data的值需要為一個(gè)字典。

http請(qǐng)求接口的調(diào)用
在HelloWorld.js文件首行添加:
var http = require('http');
實(shí)現(xiàn)如下函數(shù):

httpRequest: function() {
    var obj = {
        'url' : 'http://127.0.0.1:8181/'
    }
    http.request(obj);
}

在onLoad中調(diào)用函數(shù):
this.httpRequest();
此時(shí)可以看到控制臺(tái)中的輸出:

03.png

四送讲,前后端數(shù)據(jù)交換格式

本示例中使用JSON作為前后端數(shù)據(jù)交換格式奸笤,JSON是一種采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)的輕量級(jí)的數(shù)據(jù)交換格式。
前端在請(qǐng)求時(shí)已經(jīng)采用JSON格式哼鬓,接下來把后端傳遞回來的數(shù)據(jù)修改成JSON格式:
將httpServer.js中的數(shù)據(jù)響應(yīng):

var response = 'Hello World';
res.write(response);

修改為:

var response = {
    'info' : 'Hello world'
};
res.write(JSON.stringify(response));

將Cocos Creator中的http.js中的數(shù)據(jù)解析:

if (httpRequest.readyState == 4) {
    console.info('http success:' + url + ' resp:' + response);
    if (typeof obj.success == 'function') {
        obj.success(response);
    }
}

修改為:

if (httpRequest.readyState == 4) {
    console.info('http success:' + url + ' resp:' + response);
    var resJson = JSON.parse(response);
    if (typeof obj.success == 'function') {
        obj.success(resJson);
    }
}

再次啟動(dòng)服務(wù)监右,前端發(fā)起請(qǐng)求,獲取到的數(shù)據(jù)如下:


04.png

五异希,頁面上顯示接收到的數(shù)據(jù)

接下來我們把從后端接收到的數(shù)據(jù)顯示到HelloWorld場(chǎng)景上秸侣。
在場(chǎng)景上添加:

  • 一個(gè)發(fā)送請(qǐng)求的按鈕,點(diǎn)擊此按鈕調(diào)用httpRequest方法,同事將httpRequest的調(diào)用從onLoad函數(shù)去除味榛。
  • 創(chuàng)建一個(gè)lable用以顯示后端獲取的數(shù)據(jù),將其和代碼關(guān)聯(lián)予跌;
    如圖:


    05.png

    修改HelloWorld.js中的代碼:

var obj = {
    'url' : 'http://127.0.0.1:8181/'
}

修改為:

var obj = {
    'url' : 'http://127.0.0.1:8181/',
    'success' : function(jsonData) {
        this.responstData.string = jsonData['info'];
    }.bind(this)
}

其中this.responstData指向上一步創(chuàng)建的顯示獲取后端數(shù)據(jù)的標(biāo)簽的變量搏色。
運(yùn)行,點(diǎn)擊“發(fā)送請(qǐng)求”按鈕券册,可以得到如下畫面:

06.png

至此我們完成了http服務(wù)的請(qǐng)求和回應(yīng)功能频轿。


代碼在這兒


參考
http://docs.cocos.com/creator/manual/zh/getting-started/introduction.html
http://nodejs.cn/api/http.html#http_http_createserver_options_requestlistener


下一篇 node.js操作redis

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市烁焙,隨后出現(xiàn)的幾起案子航邢,更是在濱河造成了極大的恐慌,老刑警劉巖骄蝇,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件膳殷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡九火,警方通過查閱死者的電腦和手機(jī)赚窃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來岔激,“玉大人勒极,你說我怎么就攤上這事÷嵌Γ” “怎么了辱匿?”我有些...
    開封第一講書人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)炫彩。 經(jīng)常有香客問我匾七,道長(zhǎng),這世上最難降的妖魔是什么媒楼? 我笑而不...
    開封第一講書人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任乐尊,我火速辦了婚禮,結(jié)果婚禮上划址,老公的妹妹穿的比我還像新娘扔嵌。我一直安慰自己,他們只是感情好夺颤,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開白布痢缎。 她就那樣靜靜地躺著,像睡著了一般世澜。 火紅的嫁衣襯著肌膚如雪独旷。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音嵌洼,去河邊找鬼案疲。 笑死,一個(gè)胖子當(dāng)著我的面吹牛麻养,可吹牛的內(nèi)容都是我干的褐啡。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼鳖昌,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了许昨?” 一聲冷哼從身側(cè)響起懂盐,我...
    開封第一講書人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎糕档,沒想到半個(gè)月后莉恼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡翼岁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年类垫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片琅坡。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡悉患,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出榆俺,到底是詐尸還是另有隱情售躁,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布茴晋,位于F島的核電站陪捷,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏诺擅。R本人自食惡果不足惜市袖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望烁涌。 院中可真熱鬧苍碟,春花似錦、人聲如沸撮执。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抒钱。三九已至蜓肆,卻和暖如春颜凯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背仗扬。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工症概, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人厉颤。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓穴豫,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親逼友。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容