openInula 正在参加 2021 年度 OSC 中国开源项目评选,请投票支持!
openInula 在 2021 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
2021 年度 OSC 中国开源项目评选 正在火热进行中,快来投票支持你喜欢的开源项目!
2021 年度 OSC 中国开源项目评选 >>> 中场回顾
openInula 获得 2021 年度 OSC 中国开源项目评选「最佳人气项目」 !
授权协议 MulanPSL-2.0
操作系统 跨平台
软件类型 开源软件
开源组织
地区 国产
投 递 者 红薯
适用人群 未知
收录时间 2023-09-23

软件简介

Inula(发音为:[ˈɪnjʊlə])。openInula 是一款用于构建用户界面的 JavaScript 库,提供响应式 API 帮助开发者简单高效构建 web 页面,比传统虚拟 DOM 方式渲染效率提升30%以上!同时 InulaJS 提供与 React 保持一致的 API,并且提供5大常用功能丰富的核心组件:状态管理器、路由、国际化、请求组件、应用脚手架,以便开发者高效、高质量的构筑基于 InulaJS 的前端产品。

技术架构

输入图片说明

核心能力

响应式API

  • openInula 通过最小化重新渲染的范围,从而进行高效的UI渲染。这种方式避免了虚拟DOM的开销,使得 openInula 在性能方面表现出色。
  • openInula 通过比较变化前后的 JavaScript 对象以细粒度的依赖追踪机制来实现响应式更新,无需用户过度关注性能优化。
  • 简洁API:
    1. openInula 提供了两组简洁直观的API--响应式 API 和与 React 一致的传统API,使得开发者可以轻松地构建复杂的交互式界面。
    2. openInula 简洁的API极大降低了开发者的学习成本,开发者使用响应式API可以快速构建高效的前端界面。

兼容 ReactAPI

  • 与 React 保持一致 API 的特性、可以无缝支持 React 生态。
  • 使用传统 API 可以无缝将 React 项目切换至 openInula,React 应用可零修改切换至 openInula。

openInula 配套组件

状态管理器/inula-X

inula-X 是 openInula 默认提供的状态管理器,无需额外引入三方库,就可以简单实现跨组件/页面共享状态。 inula-X 与 Redux 比可创建多个 Store,不需要在 Reducer 中返回 state 并且简化了 Action 和 Reducer 的创建步骤,原生支持异步能力,组件能做到精准重渲染。inula-X均可使用函数组件、class 组件,能提供 redux 的适配接口及支持响应式的特点。

路由/inula-router

inula-router 是 openInula 生态组建的一部分,为 openInula 提供前端路由的能力,是构建大型应用必要组件。 inula-router 涵盖 react-router、history、connect-react-router 的功能。

请求/inula-request

inula-request 是 openInula 生态组件,涵盖常见的网络请求方式,并提供动态轮询钩子函数给用户更便捷的定制化请求体验。

国际化/inula-intl

Inula-intl 是基于 openInula 生态组件,其主要提供了国际化功能,涵盖了基本的国际化组件和钩子函数,便于用户在构建国际化能力时方便操作。

调试工具/inula-dev-tools

inula-dev-tools 是一个为 openInula 开发者提供的强大工具集,能够方便地查看和编辑组件树、管理应用状态以及进行性能分析,极大提高了开发效率和诊断问题的便捷性。

脚手架/inula-cli

Inula-cli 是一套针对 openInula 的编译期插件,它支持代码优化、JSX 语法转换以及代码分割,有助于提高应用的性能、可读性和可维护性。

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论

点击加入讨论🔥(10) 发布并加入讨论🔥
暂无内容
发表了博客
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
发表了问答
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
暂无内容
10 评论
11 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部