当前位置: 首页 > wzjs >正文

红桥天津网站建设seo教学免费课程霸屏

红桥天津网站建设,seo教学免费课程霸屏,品牌网络营销推广,温州网站建设团队当前需求是在原有的cocos手机游戏里嵌入另一个cocos的web-mobile项目 所以需要使用webview 记录一下 首先就是要有一个webview组件 接下来是脚本 (外部项目) export class GameWebview extends Component {property(WebView)webview: WebView null!;…

当前需求是在原有的cocos手机游戏里嵌入另一个cocos的web-mobile项目
所以需要使用webview
记录一下

首先就是要有一个webview组件
在这里插入图片描述
接下来是脚本
(外部项目)

export class GameWebview extends Component {@property(WebView)webview: WebView = null!;onAdded(params: any) {// webview跳转 并向内部发送tokenlet token = params.access_token;this.webview.url = `${params.host}?token=${token}`;// webview加载完成监听this.webview.node.on(WebView.EventType.LOADED, ()=> {// 约定的关键字let scheme = "closepage";// 设置关键字this.webview.setJavascriptInterfaceScheme(scheme);// 识别到URL前缀为关键字的回调this.webview.setOnJSCallback(()=>{this.close();})// 关闭背景音乐oops.audio.stopMusic();// 原本是想用这种方式发送token的,但是没有获取的时机// this.scheduleOnce(()=> {//     this.webview.evaluateJS(`setToken(${JSON.stringify(token)})`);// }, 8)})}close() {// 打开背景音乐let bgm = oops.storage.get("game_audio");oops.audio.playMusicLoop(bgm);oops.gui.remove(UIID.HitMoleGameWebview);}
}

(内部项目)
在Main.ts即项目开始时获取token

const token = urlParams.get("token");
oops.storage.set("token", token);

返回到外部游戏

close() {SocketManager.getInstance().close();// 跳转以关键字为前缀的URL,让外部webview识别document.location = 'closepage://a=1';oops.gui.remove(UIID.Home);
}

一些遇到的问题及解决

传递token

一开始我是想通过👇这种方式转递token
记得要stringify一下

this.webview.evaluateJS(`setToken(${JSON.stringify(token)})`);

获取的话就要通过声明全局方法setToken来接收
但找不到合适的时机
我已经在首场景下挂载的脚本(Main.ts)里声明了,但是还是接收不到,会报错找不到该方法(难道要改构建后的文件?)
然后我又尝试了在加载完成监听里发送token,还是同样不行

this.webview.node.on(WebView.EventType.LOADED, ()=> {this.webview.evaluateJS(`setToken(${JSON.stringify(token)})`);
})

再然后又加了个延时,倒是可以了,但是不是很稳定

this.webview.node.on(WebView.EventType.LOADED, ()=> {this.scheduleOnce(()=> {this.webview.evaluateJS(`setToken(${JSON.stringify(token)})`);}, 8)
})

最后就直接用url来传了

this.webview.url = `${params.host}?token=${token}`;

接收

const urlParams = new URLSearchParams(window.location.search);
const token = urlParams.get("token");

内部向外部传递消息

一开始我是这么设置关键字的

let scheme = "closepage";
this.webview.setJavascriptInterfaceScheme(scheme);
this.webview.setOnJSCallback(()=>{this.close();
})
let token = params.access_token;
this.webview.url = `${params.host}?token=${token}`;

看了半天,并没有啥问题啊,就是识别不了关键字
看了这篇帖子
应该是要先打开webview的内部项目,激活,再去设置关键字,为了保险我是在loaded里设置的关键字

this.webview.node.on(WebView.EventType.LOADED, ()=> {// 约定的关键字let scheme = "closepage";// 设置关键字this.webview.setJavascriptInterfaceScheme(scheme);// 识别到URL前缀为关键字的回调this.webview.setOnJSCallback(()=>{this.close();})
})

还有注意关键字不能有大写字母!!

web-mobile打包问题

打包时要注意,记得勾选上MD5,这样重新上传新包后就不用清缓存才能加载新包内容了
在这里插入图片描述

细节问题

  • 记得跳转时要记得关闭原bgm,返回时重新播放bgm
  • 如果内部项目是用的浏览器预览,可以选择”网页全屏“
    在这里插入图片描述
http://www.dtcms.com/wzjs/349932.html

相关文章:

  • 北京平面设计网站手机打开国外网站app
  • wordpress记录用户ipseo外包收费
  • 昌邑网站建设青岛网站设计微动力
  • 做网站的公司 设计好seo的基本步骤是什么
  • 做国外网站衣服码数要怎么写bing搜索引擎
  • 济南网站建设新风向百度旧版本下载
  • 西安网站建设畅网seo厂商
  • 做王境泽表情的网站seo软件推荐
  • 百度移动网站排名网站模板免费
  • 昌平区做网站网站优化排名哪家好
  • vipkid网站开发团队有没有可以代理推广的平台
  • 做运动鞋的网站视频软文类型
  • h5语言网站制作精准客户数据采集软件
  • 加盟型网站建设手机网页链接制作
  • 石家庄疫情最新情况通报北京百度seo公司
  • 做网站用云虚机还是ecs中央人民政府
  • 做电影网站要不要收费网络推广营销方法
  • 好的设计网站沧州网站推广优化
  • 鹏牛网做网站怎么样爱站网 关键词挖掘
  • 网站的专题模板制作软件谷歌商店app下载
  • 北京 个人网站 备案快照网站
  • 做原创品牌服饰的网站360免费建站网页链接
  • 做网站优化的好处石家庄百度seo代理
  • 高校网站推广方案免费外链发布平台在线
  • 设计软件网站搜索引擎关键词怎么优化
  • 晋中建设机械网站关键词优化搜索排名
  • 线下引流推广方法班级优化大师
  • 台州网站优化net的网站建设
  • 在线作图免费网站软文推广模板
  • 爱情动做网站推荐百度推广代理商有哪些