Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@hzab/data-model

Package Overview
Dependencies
Maintainers
0
Versions
22
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@hzab/data-model

data model

  • 1.4.0
  • npm
  • Socket score

Version published
Weekly downloads
10
increased by66.67%
Maintainers
0
Weekly downloads
 
Created
Source

@hzab/data-model

组件模板

  • node@14.21

组件

示例

import DataModel, {
  // 设置 token 到 localStorage 及 cookie,可以设置 opt.hasCookie(setToken(token, { hasCookie: false })) 关闭设置 token 到 cookie 上
  setToken,
  // 从 cookie 或 localStorage 获取 token
  getToken,
  // 设置默认兜底的错误信息
  setDefaultErrMsg,
  // 设置默认网络异常的错误信息
  setNetworkErrMsg,
  // 设置 DataModel 中默认的 axios
  setDefaultAxios,
} from "@hzab/data-model";

const listDM = new DataModel({
  // query 参数
  query,
  // 新增接口 post url
  createApi,
  // 新增接口 post 入参枚举函数
  createMap,
  // 详情接口 get url
  getApi,
  // 详情接口 get 出参枚举函数
  getMap,
  // 详情接口 get url
  getListApi,
  // 列表接口 get 出参枚举函数
  getListMap,
  // 列表请求函数
  getListFunc,
  // 编辑接口 put url
  updateApi,
  // 编辑接口 put 入参枚举函数
  updateMap,
  // 删除接口 delete url
  deleteApi,
  // 批量删除接口 delete url
  multipleDeleteApi,
  // 统一 response 回调,用于处理定制 response 格式
  handleResponse,
  // axios 实例对象
  axios,
  // axios 相关配置
  axiosConf,
  // getList 接口 axios 相关配置
  getListAxiosConf,
  // get 接口 axios 相关配置
  getAxiosConf,
  // create 接口 axios 相关配置
  createAxiosConf,
  // update 接口 axios 相关配置
  updateAxiosConf,
  // delete 接口 axios 相关配置
  deleteAxiosConf,
  // multipleDelete 接口 axios 相关配置
  multipleDeleteAxiosConf,
  // 列表接口 get 入参枚举函数
  getListReqMap,
  // 列表接口 get 出参枚举函数
  getListResMap,
  // 详情接口 get 入参枚举函数
  getReqMap,
  // 详情接口 get 出参枚举函数
  getResMap,
  // 新增接口 post 入参枚举函数
  createReqMap,
  // 新增接口 post 出参枚举函数
  createResMap,
  // 编辑接口 put 入参枚举函数
  updateReqMap,
  // 编辑接口 put 出参枚举函数
  updateResMap,
  // 删除接口 delete 入参枚举函数
  deleteReqMap,
  // 删除接口 delete 出参枚举函数
  deleteResMap,
  // 批量删除接口 delete 入参枚举函数
  multipleDeleteReqMap,
  // 批量删除接口 delete 出参枚举函数
  multipleDeleteResMap,
  // 是否返回完整的接口数据(response.data)
  isResponseData,
  // 是否直接返回 response
  isResponse,
});

// useDataModel,解决 hooks 写法 model 重复实例化导致 query 丢失的问题
function Demo({ orgId }) {
  // 第一个入参同 new DataModel,第二个参数为需要监听的动态参数数组
  const model = useDataModel(
    // 初始值
    {
      getListApi: "/getList",
      query: { orgId },
    },
    {
      // 动态的 params 数据
      effectParams: { orgId },
      // 动态 query 数据
      effectQuery: { orgId },
      // 动态数据监听的值
      effectTargets: [orgId],
    },
  );
  return <ListRender model={model} />;
}

DataModel

参数类型必填默认值说明
queryObject-query 参数对象
createApistring-post 接口地址
getApistring-详情 get 接口地址
getListApistring-列表 get 接口地址
updateApistring-put 接口地址
deleteApistring-delete 接口地址
multipleDeleteApistring-批量删除 delete 接口地址
createMapFunction-createApi 接口提交前的处理函数
getMapFunction-getApi 接口返回结果的处理函数
getListMapFunction-getListApi 接口返回结果的处理函数
getListFuncFunction-自定义的列表请求函数,优先级高于 getListApi
updateMapFunction-updateApi 接口提交前的处理函数
axiosObject-axios 实例对象
axiosConfObject-axios 相关配置
getListAxiosConfObject-getList 接口 axios 相关配置
getAxiosConfObject-get 接口 axios 相关配置
createAxiosConfObject-create 接口 axios 相关配置
updateAxiosConfObject-update 接口 axios 相关配置
deleteAxiosConfObject-delete 接口 axios 相关配置
multipleDeleteAxiosConfObject-multipleDelete 接口 axios 相关配置
getListReqMapFunction-列表接口 get 入参枚举函数
getListResMapFunction-列表接口 get 出参枚举函数
getReqMapFunction-详情接口 get 入参枚举函数
getResMapFunction-详情接口 get 出参枚举函数
createReqMapFunction-新增接口 get 入参枚举函数
createResMapFunction-新增接口 get 出参枚举函数
updateReqMapFunction-编辑接口 get 入参枚举函数
updateResMapFunction-编辑接口 get 出参枚举函数
deleteReqMapFunction-删除接口 get 入参枚举函数
deleteResMapFunction-删除接口 get 出参枚举函数
multipleDeleteReqMapFunction-批量删除接口 get 入参枚举函数
multipleDeleteResMapFunction-批量删除接口 get 出参枚举函数
isResponseDataboolean-是否返回完整的接口数据(response.data)
isResponseboolean-是否直接返回 response
handleResponseFunction-统一 response 回调,用于处理定制 response 格式

useDataModel

参数类型必填默认值说明
initParamsObject-初始参数,通同 DataModel
optObject-配置参数
opt.effectTargetsObject-动态数据监听的目标
opt.effectParamsObject-动态的 params 数据,包含了 query
opt.effectQueryObject-动态的 query 数据

组件开发流程

  • 在 config/webpack.config.js 中按需修改 library 配置的文件名
  • 在 config/webpack.config.js 中按需修改 alias 配置的包名,便于本地调试
  • 在 tsconfig.json 中按需修改 paths 配置的包名,解决 ts 报错问题
  • npm run dev

文件目录

  • example 本地开发测试代码
  • src 组件源码
  • lib 组件打包编译后的代码

命令

  • Mac 执行该命令,设置 pre-commit 为可执行文件

    • npm run mac-chmod
    • chmod +x .husky && chmod +x .husky/pre-commit
  • 生成文档:npm run docs

  • 本地运行:npm run dev

  • 打包编译:npm run build

发布

  • 注意:示例代码生效,但发布之后未生效。确认是否执行了编译!!!

  • 编译组件:npm run build

  • 命令:npm publish --access public

  • 发布目录:

    • lib
    • src

配置

配置文件

  • 本地配置文件:config/config.js

webpack 配置文件

  • config/webpack.config.js

FAQs

Package last updated on 26 Jul 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc