为什么捐赠
API 资源管理器
升级指南
新增!
quasar.config 文件
转换为使用 Webpack 的 CLI
浏览器兼容性
支持 TypeScript
目录结构
命令列表
CSS 预处理器
路由
延迟加载 - 代码分割
处理资源
启动文件
预取功能
API 代理
处理 Webpack
处理 process.env
使用 Pinia 进行状态管理
使用 Vuex 进行状态管理
代码检查器
测试和审计
开发移动应用
Ajax 请求
将开发服务器开放到公网
Quasar CLI 与 Webpack - @quasar/app-webpack
Cordova 插件

您可以通过使用 Cordova 插件 来挂钩到原生设备 API。

Cordova 插件

一些此类插件的示例

  • 电池状态
  • 相机
  • 联系人
  • 设备
  • 设备运动
  • 地理位置
  • 媒体
  • 媒体捕获
  • 网络信息
  • 启动画面
  • 振动
  • 状态栏

Deviceready 事件

您会注意到,某些 Cordova 插件只有在触发 deviceready 事件后才能使用。我们不必太担心它。Quasar 监听此事件,并确保我们的根 Vue 组件在此事件触发 **之后** 挂载。但是,如果您需要某个插件的自己的变量,并且该变量在 deviceready 之后初始化,则可以按照下面使用 device 插件的示例进行操作。

注意事项

让我们以一个 vue 文件为例

<template>
  ... we are sure 'deviceready' has been triggered here ...
</template>

<script>
// outside of the default export,
// we need to listen to the event for ourselves:
document.addEventListener('deviceready', () => {
  // it's only now that we are sure
  // the event has triggered
}, false)

export default {
  // we are sure 'deviceready' has been triggered here
}
</script>

原因很简单。Quasar 监听该事件,然后挂载根 Vue 组件。但在此之前,Vue 文件会被导入到 /src/router/routes.js 文件中,因此默认导出之外的代码会执行。

使用 Cordova 插件

让我们通过一些示例来学习,假设您已将 Cordova 模式添加到您的 Quasar 项目中并已安装了一个平台(android、ios 等)。

示例:电池状态

第一步是阅读我们想要使用的 Cordova 插件的文档。我们查看 Cordova 插件列表 并点击 电池状态文档页面

我们看到了有关如何安装此插件的说明。它始终是一个 Cordova 命令。**因此,我们“cd”到 /src-cordova**(这是一个 Cordova 生成的文件夹)**并从那里发出安装命令**

# from /src-cordova:
$ cordova plugin add cordova-plugin-battery-status

现在让我们将此插件用于一些好的用途。在您的 Quasar 项目的页面/布局/组件 Vue 文件之一中,我们编写

// some Vue file
// remember this is simply an example;
// only look at how we use the API described in the plugin's page;
// the rest of things here are of no importance

<template>
  <div>
    Battery status is: <strong>{{ batteryStatus }}</strong>
  </div>
</template>

<script>
import { ref, onBeforeUnmount } from 'vue'

export default {
  setup () {
    const batteryStatus = ref('determining...')

    function updateBatteryStatus (status) {
      batteryStatus.value = `Level: ${status.level}, plugged: ${status.isPlugged}`
    }

    // we register the event like on plugin's doc page
    window.addEventListener('batterystatus', updateBatteryStatus, false)

    onBeforeUnmount(() => {
      // we do some cleanup;
      // we need to remove the event listener
      window.removeEventListener('batterystatus', updateBatteryStatus, false)
    })

    return {
      batteryStatus
    }
  }
}
</script>

示例:相机

第一步是阅读我们想要使用的 Cordova 插件的文档。我们查看 Cordova 插件列表 并点击 相机文档页面

提到了 deviceready 事件。但我们已经从前面的章节了解了如何处理它。

我们阅读了有关如何安装此插件的说明。它始终是一个 Cordova 命令。**因此,我们“cd”到 /src-cordova**(这是一个 Cordova 生成的文件夹)**并从那里发出安装命令**

# from /src-cordova:
$ cordova plugin add cordova-plugin-camera

现在让我们将此插件用于一些好的用途。在您的 Quasar 项目的页面/布局/组件 Vue 文件之一中,我们编写

// some Vue file
// remember this is simply an example;
// only look at how we use the API described in the plugin's page;
// the rest of things here are of no importance

<template>
  <div>
    <q-btn color="primary" label="Get Picture" @click="captureImage" />

    <img :src="imageSrc">
  </div>
</template>

<script>
import { useQuasar } from 'quasar'
import { ref } from 'vue'

export default {
  setup () {
    const $q = useQuasar()
    const imageSrc = ref('')

    function captureImage () {
      navigator.camera.getPicture(
        data => { // on success
          imageSrc.value = `data:image/jpeg;base64,${data}`
        },
        () => { // on fail
          $q.notify('Could not access device camera.')
        },
        {
          // camera options
        }
      )
    }

    return {
      imageSrc,
      captureImage
    }
  }
}
</script>

示例:设备

第一步是阅读我们想要使用的 Cordova 插件的文档。查看 Cordova 插件列表 并点击 设备文档页面

此插件初始化一个名为 device 的全局变量,该变量描述了设备的硬件和软件。因此,可以使用 window.device 访问它。

阅读其 cordova 文档页面上有关如何安装此插件的说明。它始终是一个 Cordova 命令。**因此,我们“cd”到 /src-cordova**(这是一个 Cordova 生成的文件夹)并**从那里发出安装命令**

# from /src-cordova:
$ cordova plugin add cordova-plugin-device

现在让我们将此插件用于一些好的用途。如果您需要在启动应用程序时获取设备信息,则必须捕获创建的事件。在您的 Quasar 项目的页面/布局/组件 Vue 文件之一中,我们编写

// some Vue file
// remember this is simply an example;
// only look at how we use the API described in the plugin's page;
// the rest of things here are of no importance

<template>
  <div>
    <q-page class="flex flex-center">
      <div>IMEI: {{ imei }}</div>
    </q-page>
  </div>
</template>

<script>
import { ref } from 'vue'

export default {
  setup () {
    const imei = ref(
      window.device === void 0
        ? 'Run this on a mobile/tablet device'
        : window.device
    )

    return {
      imei
    }
  }
}
</script>