Titanium Text Textfield值到新窗口

时间:2013-06-24 03:48:28

标签: javascript function javascript-events titanium parameter-passing

我正在尝试使用文本字段的值并使用Ti.App.fireEvent(http://docs.appcelerator.com/titanium/latest/#!/api/Titanium.App-method-fireEvent)将其传递到新窗口(Javascript文件),这样我最终可以在按钮时将其插入数据库被按下...到目前为止,我有一个变量存储名为usernameValue的文本字段的值。然后将其发送到http参数值。我必须要有一些简单的东西。如果需要更多信息以使这个问题更加明确,请告诉我。

TexField数据最初来自:

var username = Titanium.UI.createTextField({
    //color : '#ffffff',
    top : 10,
    width : 300,
    height : 45,
    hintText : 'Username',
    keyboardType : Titanium.UI.KEYBOARD_DEFAULT,
    returnKeyType : Titanium.UI.RETURNKEY_DEFAULT,
    borderStyle : Titanium.UI.INPUT_BORDERSTYLE_ROUNDED,
    clearButtonMode: Titanium.UI.INPUT_BUTTONMODE_ONFOCUS
});

需要从login.js传递:

//FireEvent parameter passing!
var usernameValue = username.value;

Ti.App.addEventListener('sendDataToScreen', function()
{
    Ti.App.fireEvent('app:populateUsername', usernameValue);
});

IM.js检索:

//FireEvent Paremeter Passing!
Ti.App.fireEvent('app:populateUsername', usernameValue);

新窗口(如果有帮助):

//if logged in, open new window!
        var IM = Ti.UI.createWindow({
            url : 'IM.js',
            navBarHidden : false,
            // fullscreen:false

        });
        IM.open();

按钮参数传递使用位置:

//posting of IM onclick to database!!
postBtn.addEventListener('click', function(e) {

    if (chatBox.value != '') {

        createReq.open("POST", "http://***.php");
        var params = {

            post : chatBox.value,
            user : _data.username
        };
        createReq.send(params);

        //tap to repload and clear
        var rd = [];
        tableview.data = rd;
        setData();

    } else {
        var blankAlert = Titanium.UI.createAlertDialog({
            title : 'Posting Error',
            message : 'Post cannot be empty',
            buttonNames : ['OK']
        });
        blankAlert.show();
    }
});

1 个答案:

答案 0 :(得分:0)

发送数据时

Ti.App.fireEvent('app:populateUsername', { "username" : usernameValue });

接收数据时

Ti.App.addEventListener('app:populateUsername', function(_data)
{
    // all the data passed
    Ti.API.info(JSON.stringify(_data));

    // the value is here
    Ti.API.info("the name passed as a parameter " + _data.username));
});