使用自定义类来处理AS3中的数据库查询

时间:2015-02-15 22:36:38

标签: php mysql actionscript-3 class urlvariables

我最近开始深入研究AS3中的自定义类(以磨练我的最佳实践编码习惯),并希望创建一个数据库类,允许用户首先实例化一个包含类中方法所需的所有信息的类。在MySQL表中添加,删除,修改(等)行(通过PHP)。当然,这涉及使用URLRequest,URLLoader等。我的问题是,是否有人想办法如何从专门包含该var数据的方法返回数据而不依赖于实质上调度事件的方法(然后必须创建一个监听器而不是将其内置到类中)。例如,

var myDB:dataBase = new dataBase("dbase","table","username","pword");

//this creates an instance of a database class with methods like:

trace(myDB.fetch(1)); //gets first row of table as a delimited string

OR

if (myDB.delete(1)) {} 
//returns Boolean true if delete of row 1 was successful

我发现下面的答案包含了一种创建返回事件的类的方法:

Combining URLRequest, URLLoader and Complete Event Listener In Actionscript 3.0?

但我希望该方法返回一个包含数据库中数据的字符串或布尔确认,而不是调度事件监听器。这是我上课的一个例子:

package com.customClasses {
    import flash.net.URLLoader;
    import flash.net.URLRequest;
    import flash.net.URLVariables;
    import flash.net.URLLoaderDataFormat;
    import flash.net.URLRequestMethod;
    import fl.events.DataChangeEvent;
    import flash.events.Event

    public class dataBase {
        public var dbs:String = "";
        public var usr:String = "";
        public var pwd:String = "";
        public var tab:String = "";
        var returnData:String = "";

    // Constructor
    public function dataBase(dbs:String, usr:String, pwd:String, tab:String) {
        this.dbs = dbs;
        this.usr = usr;
        this.pwd = pwd;
        this.tab = tab;
    }

    public function fetch(idn:uint, par:String):String { 
        var returnData:String = "blank";
        var vUrlReq:URLRequest = new URLRequest ("dBase.php");
        var vUrlVars:URLVariables = new URLVariables(); 

        function onLoadVarsComplete(event:Event): void {
            //retrieve success variable from our PHP script:
            if(event.target.data.msg == "success") {
                var rawData:URLVariables = new URLVariables( event.target.data );
                returnData = rawData.fromPHP;
            } else {
                returnData = "failed!";
            }
        }
        vUrlReq.method = URLRequestMethod.POST;    
        vUrlVars.dir=dbs; // name of table affected
        vUrlVars.alpha=usr; // username
        vUrlVars.beta=pwd;  // password
        vUrlVars.dbase=tab; // name of table affected
        vUrlVars.func="fetch"; // function for php script to use
        vUrlVars.idnum=idn; //if >0 search for record with that id
        vUrlReq.data = vUrlVars;
        var vLoader:URLLoader = new URLLoader (vUrlReq);
        vLoader.addEventListener("complete", onLoadVarsComplete);
        vLoader.dataFormat = URLLoaderDataFormat.VARIABLES;
        vLoader.load(vUrlReq);

        return (returnData);
    }

returnData返回"空白" ...所以我意识到我的方法没有按预期工作。我也意识到我的returnData字符串存在一些范围问题,而且我使用的是嵌套函数(可能是禁止的)。不然,有什么想法吗?

2 个答案:

答案 0 :(得分:0)

要做你想做的事,你可以使用回调函数或DataEvent监听器,如下所示:

DB.as:

package  {

    import flash.net.*;
    import flash.events.*;

    public class DB extends EventDispatcher {       

        public static const DATA_LOADED = 'data_loaded';

        public function DB() {
        }

        public function getDataUsingDataEvent(file_path:String):void {

            var url_loader:URLLoader = new URLLoader();
                url_loader.addEventListener(
                    Event.COMPLETE, 
                    function(e:Event):void
                    {
                        var event:DataEvent = new DataEvent(DATA_LOADED, true, false, url_loader.data);
                        dispatchEvent(event);
                    }
                )
                url_loader.load(new URLRequest(file_path));     
        }

        public function getDataUsingCallback(file_path:String, callback:Function):void {

            var url_loader:URLLoader = new URLLoader();
                url_loader.addEventListener(
                    Event.COMPLETE, 
                    function(e:Event):void 
                    {
                        callback(url_loader.data);
                    }
                )
                url_loader.load(new URLRequest(file_path));     
        }

    }

}

然后:

var db:DB = new DB();

    db.addEventListener(
        DB.DATA_LOADED, 
        function(event:DataEvent):void {
            trace(event.data);
        }
    )   
    db.getDataUsingDataEvent('file_path');

    db.getDataUsingCallback(
        'file_path', 
        function(data:String):void {
            trace(data);
        }
    )

希望可以提供帮助。

答案 1 :(得分:0)

正如您所说,这不能在AS3中完成。在返回函数并继续执行脚本之前,您不能等待异步操作(例如URLLoader/load())。

如果您不想使用addEventListener()那么多,可以做的就是通过回调或实施method chaining promises。这些模式不一定比使用事件更好,并且有自己的问题,但是让你编写可以说作为序列更具可读性的代码。这些模式在Javascript(与ActionScript具有相同的异步行为)中很常见,例如jQuery。小心"callback hell"和"训练残骸"。这些技术旨在使事情更易于编写,但有时会使事情更容易出错。