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>

问题一是当我调用 CFC 时,出现 CFC 页面;出现 CFC 描述(在要求管理员通行证后)。我不想加载 QueryData.cfc;我想在 QueryData.cfc 中执行函数。

第二个问题是我无法弄清楚将参数传递给 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>?这要容易得多。

但要回答你的问题,GET url 应该是XXX.cfc?method=whatever&param=xyz

编辑:顺便说一句,您的函数应该具有access="remote",并且返回 Query 对象不是一个好主意,除非您使用<cfgrid>.

于 2010-03-04T18:19:45.347 回答