跳过主要内容
__CAPGO_KEEP_10__

使用 SvelteKit 和 Capacitor 构建移动应用

了解如何使用 SvelteKit、Capacitor 构建移动应用,并使用 Konsta UI 提升原生 UI

马丁·多纳迪厄

马丁·多纳迪厄

内容营销

使用 SvelteKit 和 Capacitor 构建移动应用

在本教程中,我们将从新建一个 SvelteKit 应用开始,然后转向使用 Capacitor 的原生移动开发。您也可以选择集成 Konsta UI 以获得 Tailwind CSS 移动 UI 的增强体验。

Capacitor 允许您轻松将 SvelteKit 网站应用转换为原生移动应用,无需进行重大修改或学习新的技能,如 React Native。

按照此步骤指南将您的 SvelteKit 应用程序转换为移动应用程序,使用 Capacitor,并如果需要,则增强您的移动 UI 使用 Konsta UI。

关于 Capacitor

CapacitorJS 是一个革命性的工具!它可以轻松地与任何 web 项目集成,包裹您的应用程序在一个本机 webview 中,并为您生成本机 Xcode 和 Android Studio 项目。其插件提供对本机设备功能的访问,例如通过 JavaScript 桥的摄像头。

Capacitor enables you to create a fantastic native mobile app without any complicated setup or steep learning curve. Its slim API and streamlined functionality make it easy to integrate into your project. You’ll be amazed at how simple it is to achieve a fully functional native app with Capacitor!

为 SvelteKit 应用程序做好准备

要创建一个新的 SvelteKit 应用程序,请运行以下命令:

npm create svelte@latest my-app
cd my-app
npm install
npm run build

在运行命令后,您应该在项目根目录看到一个新文件夹。 build 此文件夹将由 __CAPGO_KEEP_0__ 后来使用,但现在我们需要正确设置它。 dist 将 __CAPGO_KEEP_0__ 添加到您的 SvelteKit 应用程序中

This folder will be used by Capacitor later, but for now, we need to set it up correctly.

在您的 SvelteKit 应用程序中添加 Capacitor

要将您的 SvelteKit 应用程序转换为移动应用程序,需要遵循以下步骤。 sync 命令。

首先,安装 Capacitor CLI 作为开发依赖项并在您的项目中设置它。在设置过程中,您可以按“回车”键以接受名称和包ID的默认值。

接下来,安装核心包和iOS和Android平台的相关包。

最后,添加平台,Capacitor 将在您的项目根目录下为每个平台创建文件夹:

# Install the Capacitor CLI locally
npm install -D @capacitor/cli

# Initialize Capacitor in your SvelteKit project
npx cap init

# Install the required packages
npm install @capacitor/core @capacitor/ios @capacitor/android

# Add the native platforms
npx cap add ios
npx cap add android

此时,您应该在您的SvelteKit项目中看到新的 iosandroid 文件夹。

这些是真正的本机项目!

为了以后访问 Android 项目,您需要安装 Android Studio。对于 iOS,您需要一台 Mac,并应安装 Xcode.

此外,您应该在项目中找到一个 capacitor.config.ts 文件,该文件包含一些基本的Capacitor设置,用于同步过程中。您需要注意的是 webDir,它必须指向您的构建命令的结果。目前,它是错误的。

要修复此问题,请打开 capacitor.config.ts 文件并更新 webDir:

import { CapacitorConfig } from '@capacitor/cli'

const config: CapacitorConfig = {
  appId: 'com.example.app',
  appName: 'my-app',
  webDir: 'build',
}

export default config

现在我们已经更新了我们的Capacitor设置,让我们将Sveltekit项目更改为静态应用程序,通过下载适当的静态适配器包:

npm i -D @sveltejs/adapter-static

安装包后,我们需要修改 svelte.config.js 文件从自动适配器更改为静态:

import adapter from '@sveltejs/adapter-static'
import { vitePreprocess } from '@sveltejs/kit/vite'

/** @type {import('@sveltejs/kit').Config} */
const config = {
// Consult https://kit.svelte.dev/docs/integrations#preprocessors
// for more information about preprocessors
  preprocess: vitePreprocess(),

  kit: {
    // adapter-auto only supports some environments, see https://kit.svelte.dev/docs/adapter-auto for a list.
    // If your environment is not supported or you settled on a specific environment, switch out the adapter.
    // See https://kit.svelte.dev/docs/adapters for more information about adapters.
    adapter: adapter({
      // default options are shown. On some platforms
      // these options are set automatically — see below
      pages: 'build',
      assets: 'build',
      fallback: null,
      precompress: false,
      strict: true
    })
  }
}

export default config

svelte.config.js 更新后,我们需要添加一个 prerender 选项,通过创建一个 +layout.js 页面 src/routes 并且在"+layout.js"中添加以下导出语句: 添加并更新后,"+layout.js"中的页面,我们需要添加我们的移动平台,重新构建我们的项目以创建"build"文件夹:

export const prerender = true

您可以通过运行以下命令来完成: 第一个命令 将会构建您的SvelteKit项目并复制静态构建,而第二个命令 将同步所有的web __CAPGO_KEEP_0__ 到native平台的正确位置,以便在app中显示 The second command

will sync all the web __CAPGO_KEEP_0__ into the right places of the native platforms so they can be displayed in an app.

npm run build
npx cap sync

You can do it by running the following commands: npm run build page, we’ll need to add our mobile platforms, re-build our project to create the npx cap sync will sync all the web code into the right places of the native platforms so they can be displayed in an app.

另外,同步命令可能会更新本机平台并安装插件,因此当您安装新__CAPGO_KEEP_0__插件时,需要重新运行 Capacitor plugins您可能没有意识到,您已经完成了整个过程,所以让我们在设备上看看应用程序! npx cap sync 构建和部署本机应用

要开发iOS应用程序,您需要安装

Xcode

,并且要开发Android应用程序,您需要安装 Android Studio 。此外,如果您打算在应用商店上发布应用程序,则需要为iOS注册Apple Developer Program,并为Android注册Google Play Console。 如果您是本机移动开发的新手,可以使用__CAPGO_KEEP_0____CAPGO_KEEP_1__轻松打开两种本机项目: iOS

If you’re new to native mobile development, you can use the Capacitor CLI to easily open both native projects:

npx cap open ios
npx cap open android

一旦您设置了本机项目,部署应用程序到连接设备就变得简单了。在 Android Studio 中,只需等待所有内容就绪,然后您就可以在不更改任何设置的情况下将应用程序部署到连接设备。以下是示例:

android-studio-run

在 Xcode 中,您需要设置您的签名账户才能将应用程序部署到真实设备,而不是仅仅是模拟器。如果您之前没有这样做,Xcode 将指导您完成该过程(但请再次注意,您需要注册开发者计划)。之后,您可以简单地点击播放以在连接设备上运行应用程序,您可以在顶部选择设备。以下是示例:

xcode-run

恭喜!您成功部署了 SvelteKit 网络应用程序到移动设备。以下是示例:

sveltekit-mobile-app

但等一下,还有更快的方法可以在开发期间完成此操作……

Capacitor Live Reload

到目前为止,您可能习惯于所有现代框架都具有热重载的功能,好消息是您可以在移动设备上实现相同的功能 在移动设备上 只需花费最少的努力!

启用对您的本地托管应用程序的访问,具有实时重载功能 On您的网络上 通过让Capacitor应用从特定的URL加载内容。

第一步是确定您的本地IP地址。如果您使用Mac,可以通过在终端中运行以下命令来找到它:

ipconfig getifaddr en0

在Windows上运行:

ipconfig

然后查找IPv4地址。

我们可以通过在文件中添加另一个条目来指示Capacitor从服务器直接加载应用程序: capacitor.config.ts 请务必使用

import { CapacitorConfig } from '@capacitor/cli';

const config: CapacitorConfig = {
  appId: 'com.example.app',
  appName: 'my-app',
  webDir: 'dist',
  bundledWebRuntime: false,
  server: {
    url: 'http://192.168.x.xx:3000',
    cleartext: true
  }
};

export default config;

正确的IP和端口 ,如上面的示例所示。现在,我们可以将这些更改应用到我们的原生项目中:

The

npx cap copy

The copy 命令与 sync但是它只会 将对 web 文件夹和配置的修改复制到 而不更新原生项目。

您可以通过 Android Studio 或 Xcode 再次部署您的应用程序。之后,如果您在 Svelte 应用程序中更改了什么 应用程序将自动重新加载 并显示更改!

请记住 如果您安装了新插件,如摄像头插件,它仍然需要重新构建原生项目。这是因为原生文件已更改,无法在实时进行。

请注意,您应该在配置中使用正确的 IP 和端口。上面的 code 块显示了示例目的地的默认 SvelteKit 端口。

使用 Capacitor 插件

让我们看看如何使用一个 Capacitor 插件的示例,之前我们提到过几次。要实现这一点,我们可以通过运行以下命令安装一个简单的插件:

npm i @capacitor/share

没有什么高大上的 分享插件,但它会弹出原生分享对话框! share() 为了实现这一点,我们现在只需要导入包并从我们的应用中调用 函数,所以让我们修改 src/routes/index.svelte

<script>
  import { Share } from '@capacitor/share';

  async function share() {
    await Share.share({
      title: 'Open Youtube',
      text: 'Check new video on youtube',
      url: 'https://www.youtube.com',
      dialogTitle: 'Share with friends'
    });
  }
</script>

<h1>Welcome to SvelteKit and Capacitor!</h1>
<button on:click={share}>Share now!</button>

到这个:

npx cap sync

如前所述,当安装新插件时,我们需要执行同步操作,然后重新部署应用到设备上。要实现这一点,请运行以下命令:

点击按钮后,您可以亲眼目睹美丽的原生分享对话框!

添加 Konsta UI 要在 Nuxt 3 应用中使用 Konsta UI,您需要先安装 tailwind

npm i konsta

此外,您还需要修改 tailwind.config.js file:

// import konstaConfig config
const konstaConfig = require('konsta/config')

// wrap config with konstaConfig config
module.exports = konstaConfig({
  content: [
    './src/routes/**/*.{svelte}',
    './src/components/**/*.{svelte}',
  ],
  darkMode: 'media', // or 'class'
  theme: {
    extend: {},
  },
  variants: {
    extend: {},
  },
  plugins: [],
})

konstaConfig 将会扩展默认(或您的自定义)Tailwind CSS 配置文件,添加一些额外的变体和辅助工具,以便于Konsta UI 的使用。

现在我们需要设置主 App 组件,以便我们可以设置一些全局参数(如 theme).

我们需要将整个应用程序包裹在 App 中,以便在 src/routes/+layout.svelte:

<script>
  import { App } from 'konsta/svelte';
</script>

<App theme="ios">
  <slot />
</App>

Example Page

现在当一切都设置好了,我们就可以在我们的 SvelteKit 页面中使用Konsta UI Svelte 组件了。

例如,让我们打开 src/routes/index.svelte 并将其更改为以下内容:

<script>
  import {
    Page,
    Navbar,
    Block,
    Button,
    List,
    ListItem,
    Link,
    BlockTitle,
  } from 'konsta/svelte';
</script>

<Page>
  <Navbar title="My App" />

  <Block strong>
    <p>
      Here is your SvelteKit & Konsta UI app. Let's see what we have here.
    </p>
  </Block>
  <BlockTitle>Navigation</BlockTitle>
  <List>
    <ListItem href="/about/" title="About" />
    <ListItem href="/form/" title="Form" />
  </List>

  <Block strong class="flex space-x-4">
    <Button>Button 1</Button>
    <Button>Button 2</Button>
  </Block>
</Page>

如果 live reload 在安装所有必要组件后仍然不一致,尝试重新启动所有内容。 一旦你完成了这一步,你应该看到一个具有某种本地化外观的移动应用,使用 SvelteKit 和 Capacitor 构建!

你应该看到以下页面作为结果:

konsta-sveltekit

结论

Capacitor 是基于现有 web 项目构建本地应用的出色选择,提供了一个简单的方式来共享 code 并保持一致的 UI。

并且通过添加 Capgo,它更容易添加实时更新到你的应用中,确保你的用户始终可以访问最新的功能和 bug 修复。

如果你想学习如何将 Capgo 添加到你的 SvelteKit 应用中,请查看下一篇文章:

了解 Capgo 如何帮助你快速构建更好的应用, 注册免费账户 今天。

继续使用 Building Mobile Apps with SvelteKit 和 Capacitor

如果您正在使用 Building Mobile Apps with SvelteKit 和 Capacitor 来规划 CI/CD 自动化,连接它与 Capgo CI/CD 在 Capgo CI/CD 中的产品工作流程 Capgo 原生构建 在 Capgo 原生构建中产品工作流程 Capgo 集成 在 Capgo 集成中产品工作流程 CI/CD 集成 在 CI/CD 集成的实现细节中 GitHub Actions 集成 为 GitHub Actions 集成的实现细节。

Capacitor 应用实时更新

当 web 层 bug 活跃时,通过 Capgo 发布修复而不是等待几天的应用商店审批。用户在后台接收更新,而本机更改保持在正常审批路径中。

立即开始

博客最新文章

Capgo 为您提供创建真正专业的移动应用所需的最佳见解。