npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

xb-request

v1.1.2

Published

web request and jsBridge client toolkit:提供给 Web 端 和 Native 端双向通信的 JSSDK

Downloads

10

Readme

【xb-request】是提供给 Web 端 和 Native 端双向通信的 JSSDK,内置了前端与 IOS,安卓交互,调用简单,能快速整合进业务开发中。目前大型项目中已深度使用,稳定可靠。

原理小预热:

1.我们开发的 h5 页面运行在端上的 WebView 容器之中,很多业务场景下 h5 需要依赖端上提供的信息/能力,这时我们需要一个可以连接原生运行环境和 JS 运行环境的桥梁,这个桥梁就是 JSB,JSB 让 Web 端和 Native 端得以实现双向通信。

2.注入式的原理是通过 WebView 提供的接口向 JS 全局上下文对象(window)中注入对象或者方法,当 JS 调用时,可直接执行相应的 Native 代码逻辑,从而达到 Web 调用 Native 的目的。

注意:我们目前就是使用的是注入式。安卓 4.2+ 和 iOS 7+以上可用,性能较好,参数长度无限制,是目前比较优的解决方案。 同时 SDK 也包含了对 axios 的二次封装,可注入自定义(request 和 response)拦截器,使用和 axios 一致,没有增加任何心智负担,方便业务使用。

1)使用 npm 安装 注:目前只支持 npm 源镜像仓库拉取

npm install xb-request

2)项目中导入

import {
  createHttpClient,
  createJSBridgeClient,
  createClientNative,
} from "xb-request";

// jsBridge初始化配置
const jsBridgeOptions = {
  // 是否运行在native环境 可选值:Y / N
  runInNative: "Y",
  // native上下文名称
  nativeContextName: "testName",
  // 调用成功回调 可进行数据处理和加工后返回promise
  onFulfilled4Resp: (res) => {
    console.log("onFulfilled4Resp-res:", res);
    return Promise.resolve(res);
  },
};
const jsBridgeClientObj = createJSBridgeClient(jsBridgeOptions);
const nativeApi = createClientNative(jsBridgeClientObj, "eventName");
console.log("nativeApi init...", nativeApi);
nativeApi
  .fireEvent("actionName")  // 异步调用使用【fireEventForAsync】 入参一致
  .then((response) => {
    console.log('response:', response)
  })
  .catch((error) => {
    console.log('error:', error)
  });


// 创建axios请求对象
// 参数对象直接参考axios配置即可
const axiosOptions = {};
const axiosRequest = createHttpClient(axiosOptions);
console.log("axiosRequest init...", axiosRequest);