- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何避免将FragmentX绑定(bind)到Fragment
我有几个文件,在这些文件中我只声明了FragmentX
与Fragment
(或ActivityX
与Activity
)的绑定(bind),以便能够将对象作为基类依赖项注入(inject)。
这些文件看起来像这样
@Module
abstract class FragmentXModule {
@Binds
@FragmentScoped
internal abstract fun bindFragment(fragmentX: FragmentX): Fragment
}
最佳答案
更新:实际上要容易得多!
我写了一个很长的答案,就是如果不复制所有代码,实际上是不可能的,那实际上是不可能的。您可以阅读下面的旧答案以供参考,我将在此处仅包括简单的解决方案。
事实证明,存在AndroidInjector.Factory
接口(interface)和AndroidInjector.Builder
类是一个很好的理由。我们可以自己实现接口(interface),而使用我们的构建器!这样,我们仍然可以继续使用Dagger Android部件来注入(inject)我们的组件,而无需自己重新创建。
不同的组件可以使用不同的构建器,最后它们只需要实现AndroidInjector.Factory<T>
即可。以下构建器显示了绑定(bind)类型和一个父类(super class)型的通用方法。
abstract class SuperBindingAndroidInjectorBuilder<S, T : S> : AndroidInjector.Factory<T> {
override fun create(instance: T): AndroidInjector<T> {
seedInstance(instance)
superInstance(instance)
return build()
}
// bind the object the same way `AndroidInjector.Builder` does
@BindsInstance
abstract fun seedInstance(instance: T)
// _additionally_ bind a super class!
@BindsInstance
abstract fun superInstance(instance: S)
abstract fun build(): AndroidInjector<T>
}
AndroidInjector.Builder
,它也允许我们绑定(bind)父类(super class)型。
@Subcomponent
interface MainActivitySubcomponent : AndroidInjector<MainActivity> {
@Subcomponent.Builder
abstract class Builder : SuperBindingAndroidInjectorBuilder<Activity, MainActivity>()
}
Activity
和
MainActivity
。
Is it possible to avoid those file creation repeat and group all bindings in one file?
Component.Builder
。 (是的,您还可以向构建器添加一个带有构造函数参数的模块,但这具有相同的效果并导致更多的代码)
@BindsInstance abstract fun activity(instance: Activity)
添加到
Subcomponent.Builder
中,并在构造组件时将其传递进来。如果您想使用AndroidInjection,则我们需要做更多的事情,我将在下面的文章中详细介绍。
@ContributesAndroidInjector
或
AndroidInjection.inject()
...
@ContributesAndroidInjector
@ContributesAndroidInjector
将为我们生成烦人的可编写样板,但我们需要修改此生成的代码。特别是,我们需要使用组件实现的不同接口(interface),唯一的选择就是自己编写样板。是的,我们当然可以创建自己的AnnotationProcessor来生成所需的样板,但这超出了此答案的范围。
The following part is outdated, but I will leave it as reference to what actually goes on within AndroidInjection. Please use the solution presented above if you want to add additional bindings.
SpecificActivity
本身绑定(bind)到了图形,但是不允许我们将其视为
Activity
。为此,我们将必须使用自己的类并将其绑定(bind)为
Activity
。也许Dagger将来会获得这样的功能。
@ContributesAndroidInjector
为我们生成的默认设置开始。这是您应该熟悉的一个。 (如果您尚未使用AndroidInjection,请不用担心,我们将在下一步中创建自己的设置)
@Component(modules = [AndroidSupportInjectionModule::class, ActivityModule::class])
interface AppComponent {
fun inject(app: App)
@Component.Builder
interface Builder {
@BindsInstance fun app(app: App) : AppComponent.Builder
fun build(): AppComponent
}
}
@Module(subcomponents = [MainActivitySubcomponent::class])
internal abstract class ActivityModule {
@Binds
@IntoMap
@ActivityKey(MainActivity::class)
internal abstract fun bindMainActivityFactory(builder: MainActivitySubcomponent.Builder): AndroidInjector.Factory<out Activity>
}
@Subcomponent
interface MainActivitySubcomponent : AndroidInjector<MainActivity> {
@Subcomponent.Builder
abstract class Builder : AndroidInjector.Builder<MainActivity>()
}
MainActivity
,甚至将其绑定(bind)到模块中的
Activity
上,但这不是我们想要的。我们希望这种绑定(bind)是自动化的。让我们看看是否可以做得更好。
AndroidInjection.inject()
。相反,我们需要创建自己的接口(interface)。本着众多Android库的精神,我将我的接口(interface)称为
AwesomeActivityInjector
。我将保持简短和简单,但是您可以阅读
AndroidInjector以获取更多信息,而我基本上只是复制了这些信息。
activity(activity : Activity)
也将允许我们将 Activity 绑定(bind)到组件。
interface AwesomeActivityInjector<T : Activity> {
fun inject(instance: T)
interface Factory<T : Activity> {
fun create(instance: T): AwesomeActivityInjector<T>
}
abstract class Builder<T : Activity> : AwesomeActivityInjector.Factory<T> {
override fun create(instance: T): AwesomeActivityInjector<T> {
activity(instance) // bind the activity as well
seedInstance(instance)
return build()
}
@BindsInstance
abstract fun seedInstance(instance: T)
@BindsInstance
abstract fun activity(instance: Activity)
abstract fun build(): AwesomeActivityInjector<T>
}
}
AndroidInjector
替换为
AwesomeActivityInjector
。
@Module(subcomponents = [MainActivitySubcomponent::class])
internal abstract class ActivityModule {
@Binds
@IntoMap
@ActivityKey(MainActivity::class)
internal abstract fun bindMainActivityFactory(builder: MainActivitySubcomponent.Builder): AwesomeActivityInjector.Factory<out Activity>
}
@Subcomponent
interface MainActivitySubcomponent : AwesomeActivityInjector<MainActivity> {
@Subcomponent.Builder
abstract class Builder : AwesomeActivityInjector.Builder<MainActivity>()
}
class App : Application() {
@Inject
lateinit var awesomeInjectors: Map<Class<out Activity>, @JvmSuppressWildcards Provider<AwesomeActivityInjector.Factory<out Activity>>>
}
object AwesomeInjector {
fun inject(activity: Activity) {
val application = activity.application as App
val factoryProviders = application.awesomeInjectors
val provider = factoryProviders[activity.javaClass] as Provider<AwesomeActivityInjector.Factory<out Activity>>
@Suppress("UNCHECKED_CAST")
val factory = provider.get() as AwesomeActivityInjector.Factory<Activity>
factory.create(activity).inject(activity)
}
}
AwesomeActivityInjector
Activity
和
MainActivity
。
class MainActivity : AppCompatActivity() {
@Inject
lateinit var mainActivity: MainActivity
@Inject
lateinit var activity: Activity
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
AwesomeInjector.inject(this)
}
}
MainActivity
绑定(bind)为
Activity
。我写了这个答案,以举例说明AndroidInjection的工作方式以及如何适应和修改它。
关于android - 如何避免将FragmentX绑定(bind)到Fragment,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49072558/
我不知道该怎么做... function f1() { var x = 10; function f2(fx) { var x; x = 6;
早期绑定(bind)和后期绑定(bind)有什么区别? 最佳答案 简短的回答是,早期(或静态)绑定(bind)是指编译时绑定(bind),后期(或动态)绑定(bind)是指运行时绑定(bind)(例如
如何在 SwiftUI View 上使用 Binding(get: { }, set: { }) 自定义绑定(bind)与 @Binding 属性。我已成功使用此自定义绑定(bind)与 @State
我经常发现自己遇到问题,即控件的两个(相关)值被更新,并且两者都会触发昂贵的操作,或者控件可能会暂时处于不一致的状态。 例如,考虑一个数据绑定(bind),其中两个值 (x,y) 相互减去,最终结果用
我想通过我的 ViewModel 控制我的一个窗口的高度和宽度。 这看起来很简单。 但没有。它不起作用。 它检查 ViewModel 的 Width但不是 Height . 奇怪的是,如果我切换 W
UI5中一次性绑定(bind)和单向绑定(bind)有什么区别? 是否有任何用户特定的用例我会使用它们? 我无法从文档中获得太多信息。 最佳答案 单程 它的作用:单向数据流。模型数据的变化(例如通过
(define make (lambda (x) (lambda (y) (cons x (list y))))) (let ((x 7) (p (make 4))) (cons
尽管我或多或少地了解什么是语言绑定(bind),但我很难理解它们是如何工作的。 例如,谁能解释一下如何为 WinAPI 制作 Java 绑定(bind)? 最佳答案 如果您搜索 Foreign Fun
谁能解释为什么我可以重新绑定(bind)列表但不能+? (binding [list vector] (list 1 3)) (binding [list +] (list 1 3)) (bi
我真的很喜欢 Caliburn 和命名约定绑定(bind),我很惊讶 可见性与“CanNAME”约定用于保护 Action 的方式不同。 据我所知, BooleanToVisibilityConver
我了解动态绑定(bind)的实现方式以及静态绑定(bind)和动态绑定(bind)之间的区别,但我只是无法理解动态绑定(bind)的定义。基本上它是一种运行时绑定(bind)类型。 最佳答案 基本上,
http://jsfiddle.net/3NRsd/ var foo = $("div").bind("click", function() { $("div").animate({"hei
这个问题我快疯了...我有一个用户控件,它有一个用于插入操作的 FormView 和一个用于所有其他操作的 GridView。 在这两个控件中,我都有一个 DropDownList,如下所示: '
我有一个绑定(bind)到 ListBox 的地址的 ObservableCollection。然后在 ItemTemplate 中,我使用 {Binding .} 绑定(bind)到当前地址记录。这
如果我有以下简单的 js/knockout 代码: .js( View 模型): var image = ko.observable('http://placehold.it/300x150'); 看
我正在 aurelia 上开发一个自定义属性,让用户在输入文本区域时从列表中进行选择。例如,用法将是这样的: 正如您可能注意到的,auto-complete是属性。现在,当我想显示提示时,我想在自定
我正在使用 EventEmitter2作为我的应用程序内部的消息总线。现在我需要绑定(bind)和取消绑定(bind)一些事件处理程序。因为我也希望他们bind将它们添加到给定的上下文中,我最终得到以
我有以下函数调用: $(".selector").on("click", callback.bind(this, param1, param2)); 在我的回调函数中,我想使用绑定(bind)的 th
我目前正在试验新的编译绑定(bind),并且(再次)达到了我在拼图中遗漏了一个小问题:为什么我必须调用 Bindings.Update?直到现在,我还认为实现 INotifyPropertyChang
我正在阅读一本关于编写 JavaScript 框架的书,并找到了这段代码。但是我不明白它是如何工作的,尤其是 bind.bind 的用法?有人知道吗? var bind = Function.prot
我是一名优秀的程序员,十分优秀!