希望有人能帮助我理解这一点:
我正在使用一个单一 Activity 应用程序和许多在同一容器中替换的 fragment ,并且我正在启用“不保留 Activity ”选项的真实设备中测试我的应用程序
添加新 fragment 时(使用 <a href="https://developer.android.com/reference/android/app/FragmentTransaction.html#replace(int,%20android.app.Fragment,%20java.lang.String)" rel="noreferrer noopener nofollow">FragmentTransaction replace()</a> 方法),我使用的是 <a href="https://developer.android.com/reference/android/app/Fragment.html#setArguments(android.os.Bundle)" rel="noreferrer noopener nofollow">setArguments()</a>将信息传递给新 fragment 的方法。它按预期工作,我可以通过 <a href="https://developer.android.com/reference/android/app/Fragment.html#getArguments()" rel="noreferrer noopener nofollow">getArguments()</a> 获得该信息在那个 fragment 里面。到目前为止一切正常......
在此之后,我将我的应用程序发送到后台。我看到堆栈中的所有 fragment 都被销毁了,同样符合预期
我将我的应用带到前台并在 getArguments() 中方法我得到一个空的 Bundle (不是 null,只是一个空对象)而不是我在 #2 中使用的数据
根据 Android 文档,setArguments() 中提供的参数将在 fragment 销毁和创建过程中保留...所以,我的问题是:
“will be retained across fragment destroy and creation”是否包括我描述的场景?
“不保留 Activity ”选项是否会混淆 getArguments()/setArguments()如果启用了?
除了“不保留 Activity ”选项之外,还有其他方法可以测试正确的 fragment 创建/销毁吗?
正确保持 fragment 参数“有效”的更好方法是什么?我可以将它们保存在 onSaveInstanceState() 中方法,但想知道除此之外是否还有更多选择。
最佳答案
Activity 和 Fragment 的娱乐性是我们团队特别关注的点之一。所以这是我们想到的一些要点。
请记住“不要保留 Activity ”会在您进入后台时破坏您的 Activity 。稍后系统将尝试恢复您的最后状态,自动重新创建最后一个 Activity 及其 fragment 。 Android 将保存必要的信息以恢复其最后状态。所以是的,应该涵盖您的场景。
根据您的流程,您可以尝试一些问题。当 Activity 在 onCreate 方法上重新创建 savedInstanceState 时,将不为空。您应该使用此信息来避免重新创建或重新附加您的 fragment 。系统会尝试为你恢复它,这就是 fragment 不能有任何构造函数的原因。
使用 FragmentTransaction。
1 - 使用 FragmentTransaction 将您的 fragment 添加到 Activity 中,而不将其添加到后台堆栈。
2 - 使用 FragmentTransaction 将之前的 fragment 替换为其他 fragment (或者可能是之前 fragment 的新实例)。当一个 fragment 被其他 fragment 替换并且它没有被添加到返回堆栈时,android 会销毁它。
您可能不需要在代码中保留参数包。安卓会为你做。但最好在 onAttach 方法( fragment 将在屏幕上可用时调用的第一个方法)中恢复包数据并将它们存储为类属性以供以后使用。
关于android - fragment - getArguments() 返回一个空包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43597468/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出