Expo大作戰(二十七)--expo sdk api之Util(expo自帶工具類),tackSnapshotAsync,Svg,SQLite

来源:https://www.cnblogs.com/gdsblog/archive/2018/03/18/8595349.html
-Advertisement-
Play Games

簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...


簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網

我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732981

【之前我寫過一些列關於expo和rn入門配置的東i西,大家可以點擊這裡查看:從零學習rn開發

相關文章:

Expo大作戰(一)--什麼是expo,如何安裝expo clinet和xde,xde如何使用

Expo大作戰(二)--expo的生命周期,expo社區交流方式,expo學習必備資源,開發使用expo時關註的一些問題

Expo大作戰(三)--針對已經開發過react native項目開發人員有針對性的介紹了expo,expo的局限性,開發時項目選型註意點等

Expo大作戰(四)--快速用expo構建一個app,expo中的關鍵術語

Expo大作戰(五)--expo中app.json 文件的配置信息

Expo大作戰(六)--expo開發模式,expo中exp命令行工具,expo中如何查看日誌log,expo中的調試方式

Expo大作戰(七)--expo如何使用Genymotion模擬器

Expo大作戰(八)--expo中的publish以及expo中的link,對link這塊東西沒有詳細看,大家可以來和我交流

更多>>

寫在二十三章以後的話,之前的翻譯,不管如何,好與不好,終究是告一段落,也把expo基礎理論的東西又深入的理解了一遍,後續expo大作戰系列將主要介紹expo sdk的api。


Util

expo中提供的一個工具類,不適合其他地方的有用實用功能(Helpful utility functions that don’t fit anywhere else),包括一些本地化/國際化的方法(including some localization / i18n methods.)。

Expo.Util.getCurrentDeviceCountryAsync()
返回當前的設備國家代碼。

Expo.Util.getCurrentLocaleAsync()
以字元串形式返回當前設備區域設置。

Expo.Util.getCurrentTimeZoneAsync()
返回當前設備時區名稱。

Expo.Util.reload()
重新載入當前的體驗(Reloads the current experience)。這將獲取並載入設備的Expo環境支持的最新可用JS。如果您已發佈新版本,這對觸發更新體驗很有用。

訂閱應用更新(Subscribing to App Updates)

Expo.Util.addNewVersionListenerExperimental(listener)

僅限Android。當您的應用程式的新版本在後臺成功下載時調用回調。

參數
listener(function) - 在後臺成功下載新版本的應用程式時調用的回調函數。

返回
一個EventSubscription對象,當您想要從偵聽器取消訂閱時,您可以調用remove()。

相關類型(Related types)

EventSubscription

從addNewVersionListenerExperimental返回。

  • remove() (function) - 取消訂閱未來更新的偵聽器。

Event

新版本可用時傳入每個事件偵聽器的對象。

  • manifest (object)  - 應用程式新版本的清單對象。

 

takeSnapshotAsync

鑒於視圖,takeSnapshotAsync將基本上截取該視圖併為您返回一個圖像。 這對於簽名板等用戶非常有用,用戶在其中繪製某些內容,然後想要從中保存圖像。

Expo.takeSnapshotAsync(view, options)

快照給定的視圖(Snapshots the given view)。

參數

  • view(number | ReactElement) - 快照視圖的ref或reactTag(也稱為節點句柄)。

options (object) —

選項圖(A map of options:):

  • format (string)  格式(字元串) - “png”| “jpg”| “jpeg”|“WEBM”
  • quality (number) 質量(數量) - 0到1之間的數字,其中0是最差的質量,1是最好的。
  • result (string)  結果(字元串) - 結果圖像的類型。 - 'file' - 返回一個文件uri。 - 'base64' - base64編碼的圖像。 - 'data-uri' - 帶有data-uri首碼的base64編碼圖像。
  • height (number) 高度(數字) - 以像素為單位的結果高度。
  • width (number)  寬度(數字) - 以像素為單位的結果寬度。

返回

選項參數中指定的格式的圖像。(從這個title可以看出,其實就是截圖)

 

SVG

Expo.Svg()

一組繪圖基元,如Circle,Rect,Path,ClipPath和Polygon。 它支持大多數SVG元素和屬性。 該實現由react-native-svg提供,併在該存儲庫中提供文檔。

import React, { Component } from 'react';
import { View, StyleSheet } from 'react-native';
import { Constants, Svg } from 'expo';

export default class App extends Component {
  render() {
    return (
      <View style={styles.container}>
        <Svg height={100} width={100}>
          <Svg.Circle
            cx={50}
            cy={50}
            r={45}
            strokeWidth={2.5}
            stroke="#e74c3c"
            fill="#f1c40f"
          />
          <Svg.Rect
            x={15}
            y={15}
            width={70}
            height={70}
            strokeWidth={2}
            stroke="#9b59b6"
            fill="#3498db"
          />
        </Svg>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    alignItems: 'center',
    justifyContent: 'center',
    paddingTop: Constants.statusBarHeight,
    backgroundColor: '#ecf0f1',
  },
});

這段代碼運行效果:

 

這一章最後在說一下sqlite,expo中對sqlite做了很好的集成,sqlite是什麼?是移動端手機內置的一個資料庫,很好的利用sqlite,你就能打造牛逼的應用程式

SQLite

該模塊提供了一個可以通過類似WebSQL的API查詢的資料庫。 資料庫在應用程式的重新啟動之間持續存在。

這裡有一個簡單的demo。 我本人也有一個項目,對sqlite的運用。

Expo.SQLite.openDatabase(name, version, description, size)

打開一個資料庫,創建它,如果它不存在,並返回一個資料庫對象。

參數

name (string) - 要打開的資料庫文件的名稱。

版本,描述和大小參數被忽略,但被函數接受以相容WebSQL規範(but are accepted by the function for compatibility with the WebSQL specification.)。

返回

返回一個資料庫對象,如下所述。

資料庫對象(Database objects)

資料庫對象通過調用返回Expo.SQLite.openDatabase()。 這樣的對象表示到設備上的資料庫的連接。 他們支持一種方法:

db.transaction(callback, error, success)

執行資料庫事務。

參數

  • callback (function)) - 表示要執行的事務的函數。 將一個Transaction(見下文)作為唯一參數,可以在其上添加SQL語句來執行。
  • error (function)) - 如果處理此事務發生錯誤,則調用它。 採用描述錯誤的單個參數。
  • success (function)  - 當事務在資料庫上完成執行時調用。

事物對象(Transaction objects)

Transaction對象作為參數傳遞給資料庫上的db.transaction()方法的回調參數(參見上文)。它允許排隊SQL語句在資料庫事務中執行。它支持一種方法:

tx.executeSql(sqlStatement, arguments, success, error)

排隊要在事務中執行的SQL語句。強烈建議作者使用?該方法的占位符功能可避免SQL註入攻擊,並且不會即時構建SQL語句。(註意這裡

參數

  • sqlStatement(string) - 包含要執行的資料庫查詢的字元串,表示為SQL。該字元串可能包含?占位符,在參數參數中列出要替換的值。
  •  arguments (array) 參數(數組) - 要替換​​的值(數字或字元串)的數組? SQL語句中的占位符。
  • success (function) 成功(功能) - 在事務處理期間查詢成功完成時調用。採用兩個參數:事務本身和一個ResultSet對象(請參見下文)以及查詢結果。
  • error (function) 錯誤(函數) - 在事務中執行此特定查詢時發生錯誤時調用。採用兩個參數:事務本身和錯誤對象。

ResultSet對象

ResultSet對象通過Transaction的tx.executeSql()方法的成功回調的第二個參數返回(參見上文)。 他們有以下形式:

{
  insertId,
  rowsAffected,
  rows: {
    length,
    item(),
    _array,
  },
}
  • insertId(number) - 插入資料庫的SQL語句所插入的行的行ID。
  • rowsAffected(number) - SQL語句更改的行數。
  • rows.length(number) - 查詢返回的行數。
  • rows.item(function) - rows.item(index)返回具有給定索引的行。 如果沒有這樣的行,則返回null。
  • rows.array(number_) - 查詢返回的實際行數組。 可以直接使用,而不是通過rows.item()獲取行。

下一張繼續介紹,這一篇主要介紹了:expo sdk api之Util(expo自帶工具類),tackSnapshotAsync,Svg,SQLite歡迎大家關註我的微信公眾號,這篇文章是否被大家認可,我的衡量標準就是公眾號粉絲增長人數。歡迎大家轉載,但必須保留本人博客鏈接!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 周五同事監控報警,有個MySQL從庫複製狀態異常,讓我幫忙排查下,經過排查發現是MySQL5.6並行複製的一個Bug所致,具體處理過程如下: 一、錯誤信息 登錄mysql從庫伺服器,檢查複製狀態 mysql錯誤日誌內容如下 二、錯誤原因 從錯誤日誌字面意思理解,出現這個錯誤是因為資料庫開啟了並行複製 ...
  • 本文內容: MongoDB的介紹 MongoDB服務端的啟動 MongoDB客戶端連接 SQL與MongoDB相關概念解釋 什麼是BSON 資料庫操作 集合操作 文檔操作 測試環境:win10 軟體版本:3.6.2 首發時間:2018-03-18 15:38 MongoDB的介紹: MongoDB ...
  • 編譯的時候 ,編譯器會把方法前面的IBAction替換成void,把屬性前面的IBOutlet移除掉,因為這些都 只是Interface Builder的標誌而已。這個IBAction方法會被UI控制項的相應事件引發,並傳入這個UI控制項作為參數,因為我們指定傳入的參數是id類型的,所以可以傳入任意類型 ...
  • 閱讀目錄 常用 搜索、導航 編寫代碼 重構 一、常用 代碼保存 描述:該操作可以用於在書寫代碼的過程中進行快速保存 調用:菜單欄 File -> Save All 快捷鍵:Ctrl + S 最大化/最小化代碼編輯視窗 描述:隱藏所有工具視窗,代碼編輯視窗會最大化/最小化 調用:菜單欄 Window ...
  • 簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...
  • 前言: 最近想要在酷安網上傳apk,註冊開發者的時候需要申請驗證,驗證需要兩個apk,一個是自己的apk(需要簽名),另外一個則是下載酷安的模板生成的一個簽名包(使用的簽名要與之前的簽名自己的apk一樣),在簽名包的生成之中,gradle報了幾條錯誤,之後經過漫長的百度,總算是完美解決,便是把這個記 ...
  • Github地址(完整Demo,歡迎下載) https://github.com/ganchuanpu/ItemGroup 效果圖 attrs.xml 獲取到各屬性 xml佈局文件 調用的activity ...
  • 簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...