前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >移动跨平台框架ReactNative图片组件Image【10】

移动跨平台框架ReactNative图片组件Image【10】

作者头像
江咏之
发布2022-06-17 14:49:49
2.2K0
发布2022-06-17 14:49:49
举报
文章被收录于专栏:技术社区技术社区

React Native,是一个混合移动应用开发框架,是目前流行的跨平台移动应用开发框架之一。React Native 采用不同的方法进行混合移动应用开发。它不会生成原生 UI 组件,而是基于 React,React Native 是一个用于构建基于 Web 的交互界面的 JavaScript 库,因此会有更丰富的 UI 体验效果,同时也能够很好地调用底层框架的UI使用。

React Native 图片组件 Image

原生 iOS 使用 UIImage 来显示一张图片,原生 Android 开发使用 ImageView 来显示图片。

React Native 对 UIImageImageView 进行封装,提供了 Image 组件用来显示图片。

img
img

Image 组件还同时解决了访问网络图片复杂的问题,把显示网络图片给简化了。

React Native 图片组件 Image

React Native 内建了图片组件 Image 来显示图片,这个组件既可以显示本地图片,也可以显示网络图片,还可以显示 base64 格式的图片。

引入组件

使用 Image 组件首先需要引入此组件,引入组件语法和引入其它组件的语法相同

代码语言:javascript
复制
import { Image } from 'react-native'

使用组件

Image 组件的基本使用语法如下

代码语言:javascript
复制
<Image 
   style  = {image_style}
   source = {image_url} 
   resizeMode = {"cover"|"contain"|"stretch"|"repeat"|"center"}
/>

Image 组件既可以显示本地图片也可以显示网络图片,但它们的语法格式有点不同。

显示本地图片的语法格式为

代码语言:javascript
复制
<Image 
   style  = {image_style}
   source = {require('./image_path')} 
   resizeMode = {"cover"|"contain"|"stretch"|"repeat"|"center"}
/>

显示网络图片的语法格式为

代码语言:javascript
复制
<Image 
   style  = {image_style}
   source={{uri: 'image_url'}
   resizeMode = {"cover"|"contain"|"stretch"|"repeat"|"center"}
/>

显示 base64 格式的图片的语法格式为

代码语言:javascript
复制
<Image 
   style  = {image_style}
   source={{uri: 'uri: data:image/png;base64,[image_base64_data]'}
   resizeMode = {"cover"|"contain"|"stretch"|"repeat"|"center"}
/>

注意: 显示网络图片和显示 base64 格式的图片,style 样式中一定要包含 widthheight 属性。

使用范例如下

显示本地图片

代码语言:javascript
复制
<Image
    source={require('/react-native/img/favicon.png')}
/>

显示网络图片

代码语言:javascript
复制
<Image
    style={{width: 50, height: 50}}
    source={{uri: 'https://facebook.github.io/react-native/docs/assets/favicon.png'}}
/>

显示 base64 格式图片

代码语言:javascript
复制
<Image
    style={{width: 66, height: 58}}
    source={{uri: ''}}
/>

属性

Image 组件有很多属性,但常用的且跨平台的属性真心不多,我们列举几个常用的介绍下。

  1. style 属性。 除了默认的跟 相同的属性外, 中的 style 属性还支持一下属性 属性类型说明borderTopRightRadiusnumber设置右上角的圆角度数,默认值为 0borderBottomLeftRadiusnumber设置左下角的圆角度数,默认值为 0borderBottomRightRadiusnumber设置右下角的圆角度数,默认值为 0borderTopLeftRadiusnumber设置左上角的圆角度数,默认值为 0borderRadiusnumber统一设置四个角的圆角度数,默认值为 0borderColorcolor设置边框的颜色borderWidthnumber设置边框的宽度,默认值为 0backgroundColorcolor设置图片组件的背景色opacitynumber设置图片组件的透明度overflowstring当组件超出屏幕宽高时是否可见, ‘visible’ 显示, ‘hidden’ 隐藏backfaceVisibilitystring定义当组件不面向屏幕时是否可见, ‘visible’ 显示, ‘hidden’ 隐藏tintColorcolor将所有非透明的图片像素改为此颜色resizeModestring设置图片如何适应图片容器,可选的值有: ‘cover’, ‘contain’, ‘stretch’, ‘repeat’, ‘center’
  2. source 属性。 source 属性用于设置图片的地址,图片地址可以是本地图片,网络图片和 base64 格式的图片。 使用方式我们上面已经介绍过了。
  3. loadingIndicatorSource 属性。 loadingIndicatorSource 属性用于加载网络图片时的 placeholder 图片。也可以说是图片加载指示器。 它的使用格式和 source 属性一样,但不能是网络图片,只能是本地图片或 base64 格式图片。
  4. resizeMethod 属性。 resizeMethod 属性用于设置图片如何适配图片组件。默认值为 auto。 可选的值有: ‘cover’, ‘contain’, ‘stretch’, ‘repeat’, ‘center’。 值说明auto由系统自己在 resizescale 之间选择resize显示之前先进行重新调整大小,当图片超出组件太多的时间建议使用此值scale缩放图片,当地图片比组件小或者图片和组件差不多大小时使用此值

范例 1

下面的代码,我们使用 Image 组件分别显示本地图片、网络图片和 base64 图片。

你需要将下面的图片下载到项目的根目录下

img
img
App.js
代码语言:javascript
复制
import React, { Component } from 'react';
import { AppRegistry, View, Image } from 'react-native';

export default class App extends Component {
  render() {
    return (
      <View>
        <Image
          source={require('./img1.jpg')}
        />
        <Image
          style={{margin:10,width: 177, height: 100}}
          source={{uri: 'https://www.twle.cn/static/i/img1.jpg'}}
        />
        <Image
          style={{margin:10,width: 66, height: 58}}
          source={{uri: ''}}
        />
      </View>
    );
  }
}

显示效果如下

React Native 图片组件 Image
React Native 图片组件 Image
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • React Native 图片组件 Image
    • React Native 图片组件 Image
      • 引入组件
      • 使用组件
      • 使用范例如下
      • 属性
    • 范例 1
    相关产品与服务
    云开发 CloudBase
    云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档