Skip to content
Youga edited this page Dec 11, 2019 · 2 revisions

glut-app-sdk

通过导入 glut-app-sdk,快速开发 glut 小程序。

用法

  • 安装

npm install glut-app-sdk

  • 在项目中引入
import sdk from "glut-app-sdk";
  • 挂载到项目根节点

以 vue 为例,react 或 angular 用法类似

Vue.prototype.$rootId = sdk.getRootElementId();
// 在根节点处挂载小程序到容器
new Vue({
  render: (h) => h(App)
}).$mount(`#${sdk.getRootElementId()}`);

// vue根节点模版
<template>
  <div :id="$rootId">
  // content
  </div>
</template>

API

sdk.fetch

通过该接口可以在任意页面向任意网站发起跨域请求

// sdk.fetch和fetch参数用法一样,可以发起GET, POST, PUT, DELETE, etc.请求
// 但是返回值序列化为字符串。相当于fetch(..).then(res=>res.text())

// 例如:向百度发起请求
sdk.fetch("https://www.baidu.com").then((res) => console.log(res));

// 发起一个post请求
fetch(url, {
  body: JSON.stringify(data),
  cache: "no-cache",
  headers: {
    "user-agent": "Mozilla/4.0 MDN Example",
    "content-type": "application/json"
  },
  method: "POST" // *GET, POST, PUT, DELETE, etc.
}).then((response) => response.json());
sdk.rmi

开发该接口旨在利用background-script能力为小程序和页面脚本提供更多的权限能力,例如系统通知、udp 通信。后续版本考虑废弃,不建议使用。

  rmi: (cmd: string, ...params: any[]) => Promise<any>;
sdk.context

获取小程序环境信息

console.log(sdk.context);
// { extBasePath: "xxxx" }
sdk.getAppInfo

获取小程序信息

sdk.getAppInfo();
// result:{ id, name, icon }
sdk.getAppId

获取小程序 Id,每个发布的小程序都有唯一的 appId

sdk.getAppId();
// "xxxxxx"
sdk.getRootElementId

获取小程序容器的 Id

小程序项目根节点需要挂载到小程序容器上,需要执行 sdk.getRootElementId()获取容器 Id 之后注入视图到对应节点。

new Vue({
  render: (h) => h(App)
}).$mount(`#${sdk.getRootElementId()}`);
sdk.setEventListener

设置监听

监听器类型包括:open、doubleOpen、close、mini、max、resize

open:小程序打开时回调
doubleOpen:小程序在打开的情况下被再次打开,默认处理是将小程序最大化
close:小程序关闭前调用。自定义了其它监听事件或者定时器等需要在这里移除。 mini: 小程序最小化
max:最大化时调用
resize: 最大化或者最小化时调用

sdk.setEventListener("close", () => {
  // 当小程序关闭时调用
});

// 只有b方法会被回调,b替换了a
sdk.setEventListener("xxx", a);
sdk.setEventListener("xxx", b);
sdk.close、sdk.maxWin、sdk.minWin

小程序视图接口

// 关闭小程序
sdk.close();

// 最大化窗口
sdk.maxWin();

// 最小化窗口
sdk.minWin();
sdk.setMenuList

添加菜单

sdk.setMenuList([
  {
    title: "主页",
    callback: () => console.log("点击了主页")
  },
  {
    title: "菜单1",
    callback: () => console.log("点击了菜单1")
  },
  {
    title: "菜单2",
    callback: () => console.log("点击了菜单2")
  }
]);
sdk.runAtPage

调用页面脚本方法

小程序和页面脚本共享 document 对象,其余环境均被隔离。不能直接在小程序中使用页面脚本对象和方法。

调用页面方法,需要通过该接口进行。

// 页面脚本

window.abc = 123;
function one() {
  return 1;
}

// 小程序脚本

sdk
  .runAtPage(function() {
    return window.abc + one();
  })
  .then((res) => {
    console.log(res); // 124
  });
sdk.saveConfig、sdk.readConfig

全局存取配置, 每个小程序的存储空间是单独的,不会自动释放空间,请仅仅用于保存必要的配置信息。

sdk.saveConfig({
  a: 233,
  b: {...}
})
// 读取配置,传入键和缺省值
sdk.readConfig({a: 111, c: 'default value'}).then(res=>{
  console.log(res) // {a: 233, c: 'default value'}
})
sdk.Log

打印日志,区分页面的 log

sdk.Log("obj:", { a: 22, b: 44 });
// [glut:__GLUT_APP_ID__] obj: {a: 22, b:44}

change log

  • 1.0.18

打开时opactiy渐变

  • 1.0.17

解决display: none时获取不到视图宽高

  • 1.0.16

切换设备时,在屏幕比较小的设备下保存的坐标在视窗之外

  • 1.0.15

去除拖拽边界限制,修改初始化坐标

Clone this wiki locally