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

把近万个源文件喂给AI之前,我先做了一件事猛

插件化架构

v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能,现在被拆分成独立的插件。

每个插件都是一个独立的 Composer 包,包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件,这些插件会在构建过程中直接编译进应用。

插件安装非常简单,通过 composer require 安装包后,在 NativeServiceProvider 中注册即可。只有注册的插件才会被编译进最终的二进制文件,这样可以保持应用体积精简,也有助于通过应用商店审核。

创建插件

插件本质上就是 Composer 包,只是多了一些额外配置。通过添加 nativephp.json 文件,开发者可以定义 PHP 类、视图文件、桥接函数、原生依赖(CocoaPods、Swift Packages、Gradle)、权限声明、JavaScript 文件等。

NativePHP 核心提供了构建钩子、生命周期钩子、服务提供者注册等机制,让插件开发体验更加顺畅。

插件可以发布到 Packagist,也可以作为项目内部代码使用,无需发布到公共仓库。这意味着应用的 Laravel 代码库可以包含构建原生应用所需的一切。

免费核心

新架构将核心包精简到最小化,应用只需包含实际使用的功能。这让应用默认就更小、更高效,也避免了应用商店审核时因包含未使用功能而被拒的问题。

NativePHP 团队将 v3 版本命名为 NativePHP Air,并将其转为 MIT 开源协议。v3 之前的版本仍然遵循原有的 Business Source License。

核心框架开源后,社区可以参与贡献,团队欢迎针对 iOS 和 Android 核心应用的 PR。

免费插件

以下插件完全免费开源(MIT 协议):

Browser - 浏览器功能

Camera - 相机调用

Device - 设备信息获取

Dialog - 原生对话框

File - 文件操作

Microphone - 麦克风调用

Network - 网络状态检测

Share - 系统分享功能

System - 系统信息

付费插件

以下功能需要单独购买插件(一次性付费,可用于无限项目):

Biometrics - 生物识别(Face ID、指纹)

Geolocation - 地理位置

Push Notifications - 推送通知(基于 Firebase)

Scanner - 扫描器

Secure Storage - 安全存储

插件市场

插件市场(Plugin Marketplace)将所有 NativePHP 插件集中展示,开发者可以发现免费和付费插件。

未来几周,市场将向第三方开发者开放,届时开发者可以在 nativephp.com 上架自己的插件,甚至可以销售自己开发的插件。例如相机滤镜插件、支付网关集成、社交登录包等。

Jump:即时设备测试

在真机上测试应用通常是一个缓慢且繁琐的过程,需要安装数 GB 的软件、模拟器和框架。而且,没有 Mac 就无法为 iPhone 构建和测试应用。

Jump 改变了这一切。

Jump 是一个安装在手机上的应用(支持 Android 和 iOS),可以在真机上测试 NativePHP 应用,无需编译任何东西,也不需要开启开发者模式。

只需运行 native:jump Artisan 命令,打开手机上的 Jump 应用扫描二维码,Laravel 应用就会直接加载到设备上,连接到本地开发服务器。

php artisan native:jump

# 或者

./native jump

NativePHP 构建速度很快,本地开发环境的改动几乎可以实时反映到设备上。未来还计划支持完整的 HMR(热模块替换)。

Jump 应用完全免费,nativephp/mobile v3 已包含运行 Jump 所需的一切。

Jump 包含所有官方 NativePHP 插件(包括付费插件),开发者可以免费试用和学习所有功能。唯一的限制是 Jump 无法测试第三方插件。

Mimi:AI 辅助编码

Mimi(取自北欧智慧之神 Mimir)是 NativePHP 提供的 AI 辅助编码功能,可以让 AI 模型帮助编写 NativePHP 应用:

直接在浏览器中创建新的 NativePHP 项目(移动端也可以)

用自然语言描述想要构建的内容,支持语音输入

直接在 Jump 中测试应用

连接 GitHub 仓库,立即获取所有应用代码

这是从想法到可运行移动应用的最快路径,完全基于 Laravel。

升级指南

如果已经安装了 nativephp/mobile,升级到 v3 的步骤如下:

从 composer.json 中移除 NativePHP 仓库(https://nativephp.composer.sh)

运行 composer remove nativephp/mobile 卸载旧版本

运行 composer require nativephp/mobile 从 Packagist 安装 v3

安装应用中使用的功能对应的插件

除了注册新插件外,应用代码基本不需要修改。安装插件后可以使用以下命令注册:

php artisan native:plugin:register vendor/plugin

# 或者

./native plugin:register vendor/plugin

快速开始

NativePHP for Mobile v3 现已发布。在手机上安装 Jump,然后在开发环境中运行以下命令:

laravel new my-mobile-app

cd my-mobile-app

composer require nativephp/mobile

php artisan native:jump

这里面有几个小坑

PHP 要求 >=8.3

在 windows 上测试,需要先安装 7-zip

我在 IOS 手机测试得,使用 php artisan native:jump 之后会弹出一个二维码,用手机上的 Jump 扫描即可。这个 Jump 目前只能在 TestFlight 上安装,打开这个安装链接即可。

很完美,至少从安装上到测试效果都很快了。效果图如下:

Laravel 现在可以零成本构建原生 iOS 和 Android 应用 NativePHP for Mobile v3 发布芽炔诜咳

http://www.jsqmd.com/news/626187/

相关文章:

  • A4988步进电机驱动库深度解析与裸机控制实践
  • VSCode搜索优化:如何快速排除node_modules和.min.js文件(附完整配置代码)
  • Python类型提示系统mypy静态检查与运行时类型验证的集成
  • 需求管理中的用户故事与用例结合方法
  • 适配机器人全场景抓取,专业厂商技术方案与实力全面盘点 - 品牌2026
  • 高性能客服系统技术内幕:通过 SpinWait 自旋等待结构体提升高频消息分发性能挥
  • AX-12A舵机底层驱动与Dynamixel协议实战指南
  • Sunshine终极指南:5步搭建你的专属游戏串流服务器,畅享跨平台云端游戏体验
  • MC74HC595A移位寄存器驱动原理与嵌入式实战
  • 2026年旋转夹爪厂家怎么选?灵活旋转夹爪技术把控与选型要点解析 - 品牌2026
  • 阿里231滑块参数n逆向实战:从环境监测到轨迹模拟的完整解析
  • 2026年Q2聚氨酯涂料找哪家:耐高温涂料、臣田稀释剂、车站钢结构防腐涂料、醇酸涂料、集装箱涂料、饮用水管道防腐涂料选择指南 - 优质品牌商家
  • 大模型水印黑科技:用Llama3给AI生成内容打隐形标签的完整教程
  • 夹持旋转一体化作业,2026年旋转夹爪厂商推荐与精度实力测评 - 品牌2026
  • YOLO-Master 与 YOLO 开始畏
  • 解决 nav2_bringup tb3_simulation_launch.py 启动 Gazebo 失败:环境变量与模型路径排查指南
  • 电子取证必备:U盘镜像分析中的FAT32/NTFS文件系统恢复技巧大全
  • 工业自动化末端执行核心:工业夹爪性能标准与选型要点解析 - 品牌2026
  • Unity TMP(TextMesh Pro)中文显示全攻略:从字体生成到编码优化
  • 告别OpenAI API费用!用Ollama+crewAI搭建免费本地AI工作流(保姆级避坑指南)
  • gStreamer 实战教程:从入门到精通的全方位指南
  • VSCode搭配FTP-Sync实现宝塔FTP服务器代码一键部署
  • matlab代码:储能参与电能量—辅助服务调频市场联合出清代码。 本代码是电力市场出清的一个重要方向
  • LSM6DS0 IMU驱动开发与低功耗事件驱动实践
  • 2026年Q2临沂老牌函授站怎么选:山东学历提升、山东成人高考报名、成人学历、成人高等教育、临沂专升本、临沂函授报名选择指南 - 优质品牌商家
  • Arduino轻量级SNMP v1/v2c嵌入式协议栈
  • QTableWidget 表格组件故
  • Avalonia UI + LiveCharts2 实战:手把手教你从GitHub克隆到跑通第一个图表
  • eM Client(eM 客户端
  • AVRDx平台ISR型PWM库:高确定性多路软件PWM方案