- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以在这里我有两个 fragment ,它们应该使用 Safe Args Navigation 将数据从一个传递到另一个。
第一个 fragment ( OrderListFragment.kt
) 应该将参数传递给第二个 fragment ( OrderDetailFragment.kt
)。
这是来自 navigation.xml
的代码 fragment :
<navigation xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/navigation"
app:startDestination="@id/loginFragment">
...
...
<action android:id="@+id/toOrderDetailFragment"
app:destination="@+id/orderDetailFragment">
<argument
android:name="orderId"
app:argType="string" /> <- This is what I want to Pass
</action>
...
...
<fragment
android:id="@+id/orderListFragment"
android:name="com.example.switchingandroidappproject.mainFragments.OrderListFragment"
android:label="OrderListFragment" >
<action
android:id="@+id/action_orderListFragment_to_orderDetailFragment"
app:destination="@id/orderDetailFragment"
app:enterAnim="@anim/slide_in_left"
app:exitAnim="@anim/slide_out_left"
app:popEnterAnim="@anim/slide_in_left"
app:popExitAnim="@anim/slide_out_left" >
</action>
</fragment>
<fragment
android:id="@+id/orderDetailFragment"
android:name="com.example.switchingandroidappproject.mainFragments.OrderDetailFragment"
android:label="OrderDetailFragment" >
<argument
android:name="orderId"
app:argType="string" />
</fragment>
...
...
...
OrderListFragment.kt
的 fragment (这是一个看起来像
this 的回收站 View )。
override fun onItemClicked(order: OutstandingOrderListPOJODataClassDataItem) {
//Navigate to Detail Fragment
Log.i("Order", "Clicked Item from order List: ${order.orderId}") <- I use this for debugging
findNavController().navigate(
NavigationDirections.toOrderDetailFragment(
order.orderId
)
)
}
Log.i()
返回我单击的项目的值。您可以在这里查看
.
OrderListFragment.kt
当我单击项目时。第二行来自
OrderDetailFragment.kt
值应该传递到的位置。
OrderDetailFragment.kt
的 fragment :
class OrderDetailFragment : Fragment(), OrderedItemListOnItemClickListener {
private val args = arguments?.let { OrderDetailFragmentArgs.fromBundle(it) }
private val selectedOrderId = args?.orderId
lateinit var adapter: OrderedItemListAdapter
private lateinit var binding: FragmentOrderDetailBinding
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
// Change action bar title
(activity as AppCompatActivity).supportActionBar?.title = "Order Details"
// View Binding for this Fragment
binding = DataBindingUtil.inflate(
inflater,
R.layout.fragment_order_detail, container, false
)
fetchOrderDetail()
fetchOrderedItemListData()
Log.i("Order", "CLicked order ID: $selectedOrderId") <- The second line of the LOg message in the screen shot is from this line.
//Inflate layout to this activity fragment
return binding.root
}
....
....
....
OrderListFragment.kt
中的所有数据从带有改造的 API 端点并在数据类中解析它们。 :
data class OutstandingOrderListPOJODataClass(
@field:SerializedName("data")
val data: List<OutstandingOrderListPOJODataClassDataItem?>? = null,
@field:SerializedName("error")
val error: Error? = null
)
data class OutstandingOrderListPOJODataClassDataItem(
@field:SerializedName("buyer_address")
@Expose
val buyerAddress: String,
@field:SerializedName("total_price")
@Expose
val totalPrice: Int,
@field:SerializedName("buyer_name")
@Expose
val buyerName: String,
@field:SerializedName("status_confirmed_yn")
@Expose
val statusConfirmedYn: String? = null,
@field:SerializedName("order_date")
@Expose
val orderDate: String,
@field:SerializedName("outlet_id")
@Expose
val outletId: String? = null,
@field:SerializedName("nip")
@Expose
val nip: String? = null,
@field:SerializedName("jumlah_product")
@Expose
val jumlahProduct: Int? = null,
@field:SerializedName("last_update")
@Expose
val lastUpdate: String? = null,
@field:SerializedName("phone_number")
@Expose
val phoneNumber: String,
@field:SerializedName("order_running_id")
@Expose
val orderRunningId: Int? = null,
@field:SerializedName("status_tagged_yn")
@Expose
val statusTaggedYn: String? = null,
@field:SerializedName("order_id")
@Expose
val orderId: String
)
最佳答案
我只是自己想办法。我需要做的只是移动 val args
的声明和 val selectedOrderId
进入OnCreated()
.
class OrderDetailFragment : Fragment(), OrderedItemListOnItemClickListener {
lateinit var adapter: OrderedItemListAdapter
private lateinit var binding: FragmentOrderDetailBinding
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
val args = arguments?.let { OrderDetailFragmentArgs.fromBundle(it) }
val selectedOrderId = args?.orderId
....
....
....
关于Android Kotlin 使用 Safe Args Navigation 传递数据返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62226694/
我有这个代码。为了让它工作,我必须使用 Args&&... 而不是 Args... 或 Args&... 我注意到 args 从 & 转换为 const& 或 && 转换为 &。 Args...Arg
当我定义类时,我总是去 Class A(object): def __init__(self, arg): self.arg = arg def print_arg(s
假设我想定义两个 {Type} 类的变量。构造函数采用 1 个参数。下面两种方式是否完全等价(编译成相同的目标代码)? Type a(arg), b(arg); 和 Type a(arg); Type
(旁白:我是一名 Perl 程序员,正如您所知,这是我的第一个重要的 Java 程序。简单的术语将不胜感激。) 我有以下启动器作为编码工作: import java.lang.reflect.*; i
Math.nextUp(arg) 始终与 arg + Math.ulp(arg) 相同,还是我遗漏了什么? System.out.println( 0.5 + Math.ulp(0.5));
今天我在学习完美转发,我创建了这个代码示例 #include #include template auto toStdFun(Function&& fun, Args&&...ar
我想知道你会选择哪个选项? putStrLn (show randomNum) putStrLn $ show randomNum (putStrLn . show) randomNum 所有选项在语
我试图在 visual studio 2012 中编译一个库,它最初是用 c++ 为 visual studio 2015 编写的。我有一个错误说 'class' missing tag。 错误消息的
我在下面的代码中遇到了运行时异常ArrayIndexOutOfBoundException,行中: if ( args[0].equals("t") || args[0].equals("time")
我有以下代码 import React, { Component } from "react"; import { Accounts } from "meteor/accounts-base"; ex
这个问题已经有答案了: Difference between Arrays and 3 dots (Varargs) in java (3 个回答) 已关闭 5 年前。 受学校线性代数 I 和 II
所以我定义了一个函数: def getDistnace(self, strings, parentD, nodeName, nodeDistance): 我用它来调用: Node.getDistnac
这个问题在这里已经有了答案: subprocess.call() arguments ignored when using shell=True w/ list [duplicate] (2 个答案
我想将参数传递给 java 应用程序,但喜欢 linux 应用程序风格。 java 中的main 方法对所有参数使用一个String 数组。在 Linux 中,大多数应用程序接受如下参数:ls -l
这是我的代码片段 #include void change(int a[]){ printf("%p\n",&a); } int main(){
我需要使用 python 3.6 subprocess.run() 函数发出以下命令: gsettings set org.gnome.shell enabled-extensions "['appl
这两个函数是否有任何有意义的不同?有什么理由通常更喜欢一个而不是另一个吗? void foo(auto x, auto &... y) { /* ... */ } template void foo(
例如: def m(arg, ...args) { println "arg: $arg" println "args: $args" } m('arg', k:'v') 输出: ar
我对 Java 还很陌生。目前正在尝试将 args[] 中给出的文件名传递给此 FileReader,但当我编译时,它说找不到指定的文件。如果我对文件名进行硬编码,它就可以正常工作。这应该如何运作?
为什么这是一个语法错误??做这件事的合适方法是什么? >>> def f(*args, option=None): File "", line 1 def f(*args, option=
我是一名优秀的程序员,十分优秀!