Bundle

根据google官方的文档(http://developer.android.com/reference/android/os/Bundle.html

Bundle类是一个key-value对,“A mapping from String values to various Parcelable types.

类继承关系:

Java.lang.Object
     Android.os.Bundle

Bundle类是一个final类:
public final class
Bundle
extends Objectimplements Parcelable Cloneable


两个activity之间的通讯可以通过bundle类来实现,做法就是:

(1)新建一个bundle类

[java]  view plain  copy
  1. Bundle mBundle = new Bundle();   
(2)bundle类中加入数据(key -value的形式,另一个activity里面取数据的时候,就要用到key,找出对应的value)

[java]  view plain  copy
  1. mBundle.putString("Data""data from TestBundle");  

(3)新建一个intent对象,并将该bundle加入这个intent对象

[cpp]  view plain  copy
  1. Intent intent = new Intent();    
  2. intent.setClass(TestBundle.this, Target.class);    
  3. intent.putExtras(mBundle);  
完整代码如下:

android mainfest.xml如下:

[java]  view plain  copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.       package="com.tencent.test"  
  4.       android:versionCode="1"  
  5.       android:versionName="1.0">  
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name">  
  7.         <activity android:name=".TestBundle"  
  8.                   android:label="@string/app_name">  
  9.             <intent-filter>  
  10.                 <action android:name="android.intent.action.MAIN" />  
  11.                 <category android:name="android.intent.category.LAUNCHER" />  
  12.             </intent-filter>  
  13.         </activity>  
  14.     <activity android:name=".Target"></activity>  
  15.     </application>  
  16.     <uses-sdk android:minSdkVersion="7" />  
  17. </manifest>   

两个类如下:intent从TestBundle类发起,到Target类。

类1:TestBundle类:

[java]  view plain  copy
  1. import android.app.Activity;    
  2. import android.content.Intent;    
  3. import android.os.Bundle;    
  4. import android.view.View;  
  5. import android.view.View.OnClickListener;  
  6. import android.widget.Button;  
  7.   
  8. public class TestBundle extends Activity {    
  9.       
  10.     private Button button1;  
  11.     private OnClickListener cl;   
  12.     public void onCreate(Bundle savedInstanceState) {    
  13.         super.onCreate(savedInstanceState);    
  14.         setContentView(R.layout.main);  
  15.           
  16.         button1 = (Button) findViewById(R.id.button1);  
  17.         cl = new OnClickListener(){  
  18.             @Override  
  19.             public void onClick(View arg0) {  
  20.                 // TODO Auto-generated method stub  
  21.                 Intent intent = new Intent();    
  22.                 intent.setClass(TestBundle.this, Target.class);    
  23.                 Bundle mBundle = new Bundle();    
  24.                 mBundle.putString("Data""data from TestBundle");//压入数据    
  25.                 intent.putExtras(mBundle);    
  26.                 startActivity(intent);  
  27.             }  
  28.         };  
  29.         button1.setOnClickListener(cl);  
  30.     }  
  31. }    

类2: Target

[java]  view plain  copy
  1. import android.app.Activity;    
  2. import android.os.Bundle;    
  3.   
  4. public class Target extends Activity{    
  5.   
  6.     public void onCreate(Bundle savedInstanceState) {    
  7.           
  8.         super.onCreate(savedInstanceState);    
  9.         setContentView(R.layout.target);    
  10.         <span style="color:#ff6600;">Bundle bundle = getIntent().getExtras();   </span> //得到传过来的bundle  
  11.         String data = bundle.getString("Data");//读出数据    
  12.         setTitle(data);    
  13.   
  14.     }    
  15. }    

布局文件:

main.xml

[java]  view plain  copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     >  
  7. <TextView    
  8.     android:layout_width="fill_parent"   
  9.     android:layout_height="wrap_content"   
  10.     android:text="@string/hello"  
  11.     />  
  12. <Button    
  13.     android:layout_width="fill_parent"   
  14.     android:layout_height="wrap_content"   
  15.     android:text="@string/button"  
  16.     android:id = "@+id/button1"  
  17.     />   
  18. </LinearLayout>  


target.xml
[java]  view plain  copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     >  
  7. <TextView    
  8.     android:layout_width="fill_parent"   
  9.     android:layout_height="wrap_content"   
  10.     android:text="@string/target"  
  11.     />  
  12. </LinearLayout>  

String.xml

[java]  view plain  copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <resources>  
  3.     <string name="hello">Hello World, TestBundle!</string>  
  4.     <string name="app_name">测试Bundle用法</string>  
  5.     <string name="button">点击跳转</string>  
  6.     <string name="target">来到target activity</string>  
  7. </resources>  
Bundle mBundle = new Bundle(); 
### 关于 NetSuite Bundle 下载与配置 NetSuite 是一种基于云的企业资源规划 (ERP) 解决方案,提供了多种功能模块和自定义选项。Bundle 是指一组预打包的功能或脚本文件,可以用于扩展 NetSuite 的核心功能。 #### 什么是 NetSuite Bundle? NetSuite Bundle 是一个压缩包,其中包含了 SuiteScript 脚本、工作流、定制记录类型和其他自定义组件。这些 Bundle 可以通过 NetSuite 自带的套件应用商店(SuiteApp Store)或其他第三方渠道获取[^2]。 #### 如何下载 NetSuite Bundle? 要下载 NetSuite Bundle,通常有以下几种方法: 1. **通过 SuiteApp 商店** 登录到 NetSuite 后台管理界面,在 `Setup` -> `SuitesCloud` -> `SuiteApp Marketplace` 中浏览可用的应用程序和插件。找到所需的 Bundle 并点击安装按钮即可完成部署[^3]。 2. **联系供应商或合作伙伴** 如果目标 Bundle 不在官方市场中提供,则可能需要直接联系开发该 Bundle 的第三方供应商或认证合作伙伴来请求访问权限或者购买许可[^4]。 3. **手动上传本地文件** 对于已经拥有的 Bundle 文件 (.zip),可以通过 `File Cabinet` 将其上传至系统内部存储区域后再执行导入操作。具体路径为:`Customization` -> `Scripts` -> `Upload File`[^5]。 #### 配置已下载的 NetSuite Bundle 一旦成功加载了一个新的 Bundle 到账户里之后,还需要对其进行必要的设置才能正常使用它的全部特性: - 进入 `Customization` -> `Scripting` -> `Deployments` 页面查看是否有待激活的新项目; - 根据提示填写相关参数比如触发条件等信息; - 测试运行确认无误后正式启用此服务实例[^6]。 以下是简单的代码片段展示如何利用 RESTlet API 来调用某个特定的服务端逻辑作为例子: ```javascript /** * Example of calling a deployed RESTlet from within another script. */ function callRestlet() { var url = nlapiResolveURL('RESTLET', 'customscript_example_restlet'); var response = nlhttp.request({ method: 'GET', url: url, headers: { 'Content-Type': 'application/json' } }); return JSON.parse(response.body); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值