今天做腾讯广告,怎么也出不来。醉了啊。
后来发现了一句话。
【修改】操作),如果广告位类型为“原生广告”,且“样式”栏显示为“上图下文”“上文下图”等选项,则表明当前广告位是原生模板广告位。如果您需要使用开发者自渲染的老接口,请您参考2.5原生广告(自渲染方式)。
老接口,我竟然没看到,在这调了半天,还以为是新接口,没有给我开通权限,
哎。
腾讯也是为了照顾新老接口,没有删,也在demo里面说的不明白。
哎
今天做腾讯广告,怎么也出不来。醉了啊。
后来发现了一句话。
【修改】操作),如果广告位类型为“原生广告”,且“样式”栏显示为“上图下文”“上文下图”等选项,则表明当前广告位是原生模板广告位。如果您需要使用开发者自渲染的老接口,请您参考2.5原生广告(自渲染方式)。
老接口,我竟然没看到,在这调了半天,还以为是新接口,没有给我开通权限,
哎。
腾讯也是为了照顾新老接口,没有删,也在demo里面说的不明白。
哎
Sealed class(密封类) 是一个有特定数量子类的类,看上去和枚举有点类似,所不同的是,在枚举中,我们每个类型只有一个对象(实例);而在密封类中,同一个类可以拥有几个对象。
修饰构造方法 修饰变量,在宿主类里,引入要注入的实例
简单的说,就是一个工厂模式,由Dagger负责创建工厂,帮忙生产instance。遵从Java规范JSR 330,可以使用这些注解。现在不研究Dagger2是如何根据注解去生成工厂的,先来看看工厂是什么东西,理解为什么可以实现了DI(Dependency Injection),如何创建IoC(Inverse of Control)容器。
1 使用Fragment参数来代替Activity参数 2 使用 @FragmentKey来代替@ActivityKey 3 使用HasFragmentInjector来代替@HasActivityInjector 4 AndroidInjection.inject(Fragment)方法,在Fragment的onAttach()中调用,而不是在onCreate()中 5 Fragment的Module添加位置,和Activity是不同的,它取决于Fragment需要的其他依赖注入
標註@Provides的method若有parameter的話,Dagger會找出其擁有的該型態物件來使用。我們在Module內新增了DataModel將其列入Dagger的管理下,接著在provideFactory()增加parameter變成provideFactory(DataModel dataModel),Dagger就會找出其管理的DataModel給provideFactory使用。
i added kapt instead of annotationProcessor for kotlin. we dont need to keep annotationProcessor dependency. Also we have to add kotlin-plugin in gradle.
As we all know, it would be Very Bad to attempt to perform constructor injection on a Fragment.
有时候有这样的需求,需要在LiveData将变化的数据通知给观察者前,改变数据的类型;或者是返回一个不一样的LiveData。
Lifecycle-aware components生命周期感知组件执行操作,以响应另一个组件生命周期状态的更改,例如Activity和Fragment。这些组件可以帮助您生成更有组织、更容易维护的轻量级代码。
Room是Google在AndroidX中提供的一个ORM(Object Relational Mapping,对象关系映射)库。它是在SQLite上提供的一个抽象层,可以使用SQLite的全部功能,同时可以更好更便捷流畅地访问数据库。(关于AndroidX可以参考