5

次のスクリプトを使用してCFC関数を呼び出しています。

function loadQuery() {
    $.get('QueryData.cfc',{},function(GetMyData){
    $("#content").html(GetMyData)
        })
    return false
    }

$(document).ready(function() {
    $("#loadLink").click(loadQuery)
});

これは私のHTMLです:

<a href="" id="loadLink">Load It</a>

<div id="content"></div>

私は次のCFCを呼んでいます:

<cffunction name="GetMyData" access="public" returntype="query">

    <cfargument name="RecordID" type="string" required="yes">

    <cfset var RecordData = "">

    <cfquery name="RecordData" datasource="MyDSN">
        SELECT
            foo.RecordID,
            foo.RecordName            
FROM
            foo
        WHERE
            foo.RecordID =  #ARGUMENTS.RecordID# ;        
    </cfquery>

    <cfreturn RecordData>

問題の1つは、CFCを呼び出すと、CFCページが表示されることです。CFCの説明が表示されます(管理者パスを要求した後)。QueryData.cfcをロードしたくありません。QueryData.cfc内で関数を実行したい。

2番目の問題は、CFCメソッドに引数を渡すための構文がわからないことです。

4

2 に答える 2

6

$ .getメソッドを使用して同様のことを行うことができますが、私は通常次のようなことを行います。

$(document).ready(function() {
    $("#loadLink").click(function(e) {
        e.preventDefault();
        var recordata = $(this).attr("href").substring(1); //trim '?' char
        $.ajax({
            type: "GET",
            url: "QueryData.cfc?method=GetMyData",
            data: recordata,
            dataType: "html",
            success: function(message) {
                $("#content").html(message);
            }
        });
    });
});

レコードIDのデータがDOMのどこかに次のように格納されている場合:

<a href="?RecordID=#url.RecordID#" id="loadLink">Load Data</a>
<div id="content"></div>

また、access = "public"でどのように動作するかはわかりませんが、それでも機能する可能性がありますが、関数ではおそらくaccess="remote"である必要があります。

于 2010-03-04T18:35:10.340 に答える
1

あなたがしていることについて、あなたは試してみません<cfdiv><cfajaxproxy>?それははるかに簡単です。

しかし、あなたの質問に答えるには、GETURLは次のようになります。XXX.cfc?method=whatever&param=xyz

編集:ところで、関数にはがaccess="remote"必要です。を使用している場合を除いて、Queryオブジェクトを返すことはお勧めできません<cfgrid>

于 2010-03-04T18:19:45.347 に答える