Fragments之间的交互(实现参数传递)

日常开发中,通常Fragments之间可能需要交互,比如基于用户事件改变Fragment的内容。所有Fragment之间的交互需要通过他们关联的Activity,两个Fragment之间不应该直接交互。

采用接口回调的方式来实现Fragments之间的交互,大致分为四步:

1.定义一个接口

  • 为了让Fragment与Activity交互,可以在Fragment类中定义一个接口,并在Activity中实现。Fragment在它们的生命周期的onAttach()方法中获取接口的实现,然后调用接口的方法来与Activity交互。

定义接口的代码如下:

public class ListFragment extends Fragment implements AdapterView.OnItemClickListener {

    private ListView mListView;
private ListAdapter mAdapter;
private List<String> mData; public ListFragment() {
// Required empty public constructor
} public static ListFragment newInstance(String type) {
Bundle args = new Bundle();
args.putString("type", type);
ListFragment fragment = new ListFragment();
fragment.setArguments(args);
return fragment;
} @Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (mData == null) {
mData = new ArrayList<>();
}
loadData();
} private void loadData() {
for (int i = 0; i < 10; i++) {
mData.add("Item" + i);
}
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fragment_list, container, false);
mListView = (ListView) rootView.findViewById(R.id.list_view); mAdapter = new ListAdapter(getActivity(), mData);
mListView.setAdapter(mAdapter);
mListView.setOnItemClickListener(this);
return rootView;
} @Override
public void onAttach(Context context) {
super.onAttach(context);
// This makes sure that the container activity has implemented
// the callback interface. If not, it throws an exception
try {
mOnListItemSelectedListener = (OnListItemSelectedListener) context;
} catch (ClassCastException e) {
throw new ClassCastException(context.toString()
+ " must implement OnListItemSelectedListener");
}
} @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
mOnListItemSelectedListener.onListItemSelected(position);
} private OnListItemSelectedListener mOnListItemSelectedListener; public interface OnListItemSelectedListener {
void onListItemSelected(int position);
} /* ================适配器相关===============*/
public class ListAdapter extends BaseAdapter { private List<String> mData;
private Context mContext; public ListAdapter(Context context, List<String> data) {
this.mContext = context;
this.mData = data;
} @Override
public int getCount() {
return mData.size() == 0 ? 0 : mData.size();
} @Override
public Object getItem(int position) {
return mData == null ? null : mData.get(position);
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
holder = new ViewHolder();
convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);
holder.mTextView = (TextView) convertView.findViewById(R.id.text_view);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
String text = mData.get(position);
if (text != null && !"".equals(text)) {
holder.mTextView.setText(text);
}
return convertView;
} public class ViewHolder {
TextView mTextView;
}
} }
  • 现在Fragment就可以通过OnListItemSelectedListener 接口实例的mOnListItemSelectedListener中的onListItemSelected()方法与Activity传递消息。
  • 我这个例子实现的是在ListFragment中点击ListView的一个Item,把这个Item的position传递给DetailFragment,DetailFragment展示具体的信息,如新闻列表,点击Item之后进入新闻详情页。
  • 当我们点击Item时,ListFragment用回调接口来传递事件给父Activity。
 @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
mOnListItemSelectedListener.onListItemSelected(position);
}

2.实现接口

  • 为了接收回调事件,宿主Activity必须实现Fragment中定义的接口。
  • MainActivity实现了ListFragment中的接口,如下代码:
public class MainActivity extends AppCompatActivity
implements ListFragment.OnListItemSelectedListener { private static final String TAG = "MainActivity"; private ListFragment mListFragment; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); mListFragment = ListFragment.newInstance("ListFragment");
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(),
mListFragment, R.id.frame_container);
} @Override
public void onListItemSelected(int position) {
Log.d(TAG, position + "");
Bundle args = new Bundle();
args.putInt("position",position);
DetailFragment fragment = DetailFragment.newInstance("DetailFragment");
fragment.setArguments(args);
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(), fragment, R.id.frame_container);
}
}

3.传递消息给Fragment

  • 宿主MainActivity中还包含了另外一个Fragment(DetailFragment),DetailFragment用来展示回调方法中指定Item的内容。在这种情况下,MainActivity可以把回调方法中接收到的position传递给DetailFragment。
 @Override
public void onListItemSelected(int position) {
Log.d(TAG, position + "");
Bundle args = new Bundle();
args.putInt("position",position);
DetailFragment fragment = DetailFragment.newInstance("DetailFragment");
fragment.setArguments(args);
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(), fragment, R.id.frame_container);
}

4.接收传递的参数

  • 在DetailFragment中接收ListFragment传递的position参数
public class DetailFragment extends Fragment {

    private TextView mTextView;
private Bundle args; public DetailFragment() {
// Required empty public constructor
} public static DetailFragment newInstance(String type) {
Bundle args = new Bundle();
args.putString("type", type);
DetailFragment fragment = new DetailFragment();
fragment.setArguments(args);
return fragment;
} @Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
args = getArguments();//获取传递的参数
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fragment_detail, container, false);
mTextView = (TextView) rootView.findViewById(R.id.text_view);
mTextView.setText(args.get("position").toString());
return rootView;
}
}

这样就实现了两个Fragment之间的交互。其核心就是拥有同一个宿主Activity的Fragments利用接口回调的方式实现参数的传递。

博客地址:http://tonycheng93.github.io/

源码地址:https://github.com/tonycheng93/Fragment2Fragment

Fragments之间的交互(实现参数传递)的更多相关文章

  1. Salesforce视图与控制器之间的交互

    刚接触Salesforce,过程的确是比较艰难了,中文资料几乎没有,看英文资料学的效率却不高,不过看了一段时间的英文资料发现自己英语水平挺高不少啊,现在看都不用工具翻译,早知道就再次尝试报个6级,看下 ...

  2. python基础--面向对象基础(类与对象、对象之间的交互和组合、面向对象的命名空间、面向对象的三大特性等)

    python基础--面向对象 (1)面向过程VS面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. ...

  3. 我的Android第五章:通过Intent实现活动与活动之间的交互

    Intent在活动的操作 作用: Itent是Android程序中各个组件直接交换的一个重要方式可以指定当前组件要执行任务同时也可以给各个组件直接进行数据交互              同时Inten ...

  4. AngularJs-指令和指令之间的交互(动感超人)

    前言: 上节我们学习到了指令和控制器之间的交互,通过给指令添加动作,调用了控制器中的方法.本节我们学习指令和指令之间是如何交互的,我们通过一个小游戏来和大家一起学习,听大漠老师说这是国外的人写的dem ...

  5. OC和JS之间的交互

    OC和JS之间的交互 目录 对OC和JS之间交互的理解 JS调用OC OC调用JS 对OC和JS之间交互的理解 JS调用OC JS文件 function sendCommand(cmd,param){ ...

  6. 安卓任意两个或多个Fragment之间的交互与刷新界面

    平时项目中遇到一个问题:在子fragment中刷新父fragment的界面,通俗的说也就是在任何一个fragment中来刷新另一个fragment.大家都知道activity和fragment之间的交 ...

  7. WPF自学入门(八)WPF窗体之间的交互

    今天我们一起来看一下WPF窗体之间的交互-窗体之间的传值.有两个窗体,一个是父窗体,一个是子窗体.要将父窗体的文本框中的值传递给子窗体中的控件.我们该怎么实现? 接下来我们一起来实现窗体之间的传值,在 ...

  8. python 全栈开发,Day18(对象之间的交互,类命名空间与对象,实例的命名空间,类的组合用法)

    一.对象之间的交互 现在我们已经有一个人类了,通过给人类一些具体的属性我们就可以拿到一个实实在在的人.现在我们要再创建一个狗类,狗就不能打人了,只能咬人,所以我们给狗一个bite方法.有了狗类,我们还 ...

  9. iOS原生和React-Native之间的交互1

    今天,记录一下iOS原生和React-Native之间的交互.如果第一次接触最好先移步至 http://www.cnblogs.com/shaoting/p/6388502.html 先看一下怎么在i ...

随机推荐

  1. 字体文件放入CDN服务器中,跨域问题(IIS版)

    Font from origin 'http:/XXXX' has been blocked from loading by Cross-Origin Resource Sharing policy: ...

  2. rsync安装配置及故障解决完全教程[window, 文件同步]

    Rsync是的全称是: remote synchronize, 也就是远程同步数据, 它是一款不错的文件同步软件,而且是免费的, 它在镜像保存整个目录树和文件系统的同时保持原来文件的权限.时间.软硬链 ...

  3. jquery 按钮效果 正常、移上、按下

    在网页设计过程中,经常遇见按钮的各状态效果.写了一个jquery扩展,使这个过程更方便! 使用前注意引用Jquery: JqueryExtend.js: (function ($) { // Butt ...

  4. ubuntu14.04 编译安装gcc-5.3.0

    最近编译个源码,要求对C++14的支持了,就GCC的编译安装最新的5.3.0,整个过程以root用户进行. 1.下载GCC源码,属于事后文档整理,已经不知道从哪下载了. 2.解压:tar -zxvf ...

  5. 受限玻尔兹曼机(RBM)学习笔记(六)对比散度算法

      去年 6 月份写的博文<Yusuke Sugomori 的 C 语言 Deep Learning 程序解读>是囫囵吞枣地读完一个关于 DBN 算法的开源代码后的笔记,当时对其中涉及的算 ...

  6. Ladda – 把加载提示效果集成到按钮中,提升用户体验

    Ladda 是一组集成了加载提示的按钮,以弥合行动和反馈之间的时间间隔,提供更好的功能使用体验.主要用于在用户点击提交之后,向用户提供即时的反馈,让他们知道浏览器正在处用户提交的任务. 您可能感兴趣的 ...

  7. Web前端面试题集锦

    前端开发面试知识点大纲: 注意 转载须保留原文链接(http://www.cnblogs.com/wzhiq896/p/5927180.html )作者:wangwen896 HTML&CSS ...

  8. JavaScript--DOM修改元素的属性

    一旦你获得了要修改的元素,可以有2种方式,来读取和修改它的属性:一种老的方式(它被更多的用户代理所支持)和一种新的DOM方法的方式.老的和新的用户代理都允许你以对象属性的方式获取和设置元素的属性. 先 ...

  9. LeetCode - 31. Next Permutation

    31. Next Permutation Problem's Link ---------------------------------------------------------------- ...

  10. 计算html标签textarea字符长度

    今天学习jQuery,做练习计算html标签textarea字符长度,先添加一个视图操作(Action): 创建一个视图,并按下面顺序标记1,2,3进行写html或javascript脚本: 其中标记 ...