Context的使用

在这里插入图片描述

大家注意看到有一些NO上添加了一些数字,其实这些从能力上来说是YES,但是为什么说是NO呢?下面一个一个解释:

数字1:启动Activity在这些类中是可以的,但是需要创建一个新的task。一般情况不推荐。

数字2:在这些类中去layout inflate是合法的,但是会使用系统默认的主题样式,如果你自定义了某些样式可能不会被使用。

数字3:在receiver为null时允许,在4.2或以上的版本中,用于获取黏性广播的当前值。(可以无视)

注:ContentProvider、BroadcastReceiver之所以在上述表格中,是因为在其内部方法中都有一个context用于使用。

好了,这里我们看下表格,重点看Activity和Application,可以看到,和UI相关的方法基本都不建议或者不可使用Application,并且,前三个操作基本不可能在Application中出现。实际上,只要把握住一点,凡是跟UI相关的,都应该使用Activity做为Context来处理;其他的一些操作,Service,Activity,Application等实例都可以,当然了,注意Context引用的持有,防止内存泄漏。

转载出处:http://blog.youkuaiyun.com/lmj623565791/article/details/40481055
本文出自:【张鸿洋的博客】

React中Context使用通常涉及以下几个关键步骤和方法: 1. **初始化Context**:使用`React.createContext()`来创建一个上下文的容器(组件),可以设置共享的默认数据。有两种常见的方式,一种是不解构`Provider`和`Consumer`,后续通过`.`的方式设置,适用于多个`context`的情况;另一种是直接解构出`Provider`和`Consumer`,适用于只有一个`context`的时候。示例代码如下: ```javascript // 没解构Provider和Consumer,后面可以通过 . 的方式设置。适用于多个context时候 const defaultContext = React.createContext(defaultValue); // 直接解构出Provider和Consumer,适用于只有一个context的时候 const { Provider, Consumer } = React.createContext(defaultValue); ``` 2. **提供Context**:使用`Provider`作为提供`context`的父组件,用来包裹需要`context`的子组件。`Provider`组件有一个`value`属性,通过它可以传递需要共享的数据或函数等。示例代码如下: ```jsx <Provider value={/* 需要共享的数据或函数 */}> {/* 子组件 */} </Provider> ``` 3. **子组件获取Context**:子组件可以使用`React.useContext()`方法来获得`context`。示例代码如下: ```jsx import React, { useContext } from 'react'; const MyContext = React.createContext(); function ChildComponent() { const contextValue = useContext(MyContext); return <div>{contextValue}</div>; } ``` 如果一个组件中只使用一个`Context`,还可以使用`contextType`代替`Consumer`,具体可参考https://www.cnblogs.com/littleSpill/p/11221817.html [^1][^4][^5]。 此外,Context在很多开发库中有着广泛的应用,如在`React-redux`中,`Context`作为`Provider`,给应用提供全局的`store`;在`React-router`中,则用`Context`提供路由状态 [^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值