Dynamic Drop Down List in ColdFusion 9

夙愿已清 提交于 2019-12-13 04:11:19

问题


Alright so people were not understanding clearly my question, so I removed the url where there was a question already asked by someone else and there I didn't got the perfect answer..

So here is the Question........

I am looking to code a dynamic drop down list within ColdFusion. What I want is the drop down list to be populated by the above drop down list (example: Select Province (B.C) will populate the City drop down list with all cities within that Province). Province data will be collected from a ColdFusion query and same with the city's data.

Please, No JavaScript, No AJAX, No ColdFusion CFCs, Nothing more than or less than some ColdFusion Tags... :( The logic code should be in one .cfm file itself.

  • Edit -

@Charles Higgins

Can't seem to make it work. It's throwing "Error invoking CFC BinFcns.cfc : Internal Server Error" "Please tell me where I'm doing it wrong, here is the code..

This one is 'index.cfm'

<cfquery name="qstates" datasource="info">
  SELECT states
  FROM info

  GROUP BY states
</cfquery> 
<html> 
<head> 
</head> 
<body> 
<cfform>
<cfselect name="DropDown1" bind="cfc:BinFcns.Method({DropDown1})">
    <cfoutput query="qstates"><option>#states#</option></cfoutput>
</cfselect>
<cfselect name="DropDown2" bind="cfc:BinFcns.Method({DropDown1})" /> 
</cfform>
</body> 
</html>

and this one is the .cfc, 'BinFcns.cfc'

<cfcomponent output="true">
   <!--- set function name --->
   <cffunction name="Method" access="remote" returnType="array">
    <!--- this is what you passed to the CFC via the {} think in the select --->
      <cfargument name="Selected" type="numeric" required="true">
      <!--- Define array to produce the drop down --->
      <cfset var data="">
      <cfset var result=ArrayNew(2)>
      <cfset var i=0>
      <!--- Get data --->
      <cfquery name="data" datasource="info">
      SELECT *
      FROM info
      Order by cities
      </cfquery> 
      <!--- Convert results to array --->
      <cfloop index="i" from="1" to="#data.RecordCount#">
             <cfset result[i][1]=data.DropDownID[i]>
             <cfset result[i][2]='#DropDownTEXT#'>      
             <!--- determine which is selected via what you passed and something in the database --->
            <cfif data.DropDownID[i] eq #Selected#>
                <cfset result[i][3]=true>
            </cfif>
      </cfloop>

      <!--- And return it --->
      <cfreturn result>
   </cffunction>
</cfcomponent>     

回答1:


Your CFC Its not complicated, trust me learn its the best option, I have not tested this code but it should be close to working.. just fugly like most of my code.

<cfcomponent output="false">
   <!--- set function name --->
   <cffunction name="Method" access="public" returnType="array">
    <!--- this is what you passed to the CFC via the {} think in the select --->
      <cfargument name="Selected" type="numeric" required="true">
      <!--- Define array to produce the drop down --->
      <cfset var data="">
      <cfset var result=ArrayNew(2)>
      <cfset var i=0>
      <!--- Get data --->
      <cfquery name="data" datasource="#THIS.dsn#">
      SELECT *
      FROM 2ndDropDownData
      Order by DataName
      </cfquery> 
      <!--- Convert results to array --->
      <cfloop index="i" from="1" to="#data.RecordCount#">
             <cfset result[i][1]=data.DropDownID[i]>
             <cfset result[i][2]='#DropDownTEXT#'>      
             <!--- determine which is selected via what you passed and something in the database --->
            <cfif data.DropDownID[i] eq #Selected#>
                <cfset result[i][3]=true>
            </cfif>
      </cfloop>

      <!--- And return it --->
      <cfreturn result>
   </cffunction>
</cffunction>      

The CFM SIMPLE!

A drop down called DropDown1, then you pass that to the cfc via the following code for drop down 2

<cfselect name="DropDown2" bind="cfc:cfcname.Method({DropDown1})" /> 

Its that simple... two drop downs, with the second one calling the CFC.. Worth learning.

You can use Bindonload, on the 2nd to preselect if required.

Anyway hope that stops you being scared of CFCs.. they are very usefull.




回答2:


I usually just write my own AJAX call with jQuery so I'm not too familiar with ColdFusion's data binding. The CFC / NOT CFC concept is the same really. You're requesting data from the server, if you used a .cfm file or a .cfc to return the data your code would be very similar.

from CFSelect Docs, The return must be:

  • A two-dimensional array, where the first element in each array row is the option value and the second element in the row is the text to display in the option list.
  • If the bind specifies a CFC function, a query, or, if the bind specifies a URL, a JSON representation of a query. The query must include columns whose names are the values of the cfselect tag value and display attributes. Although you can return additional columns, you cannot use them in your client-side code. When you call a CFC function, you do not have to convert the query to JSON format yourself; ColdFusion automatically does the conversion. To use this format, you must specify a value attribute. If you omit the display attribute, you must have only a single column in the query that contains the values; the values are also used as the displayed text.

From Binding data to form fields:

Using bind expressions To specify a bind expression, use one of the following formats:

  • cfc:componentPath.functionName(parameters) Note: The component path cannot use a mapping. The componentPath value must be a dot-delimited path from the web root or the directory that contains the current page.
  • javascript:functionName(parameters)
  • url:URL?parameters
  • URL?parameters
  • A string containing one or more instances of {bind parameter}, such as {firstname}.{lastname}@{domain}



回答3:


I am sure some people will scream in horror, but here is something I used to do as a newbie if you want a dynamic select.

Query the Table, to get values

<cfquery datasource="xy" name="get">
 Select *
 From Data
</cfquery>

Just stick the output inside the select, and if you want to be cocky use a CFIF to determine which bit you are viewing. You do not need to use CFSELECT, select can do.

<cfselect name="select">
  <cfoutput query="get">
    <option value="#URLTAKENFROMDATABASE#"
    <cfif #CGI.SCRIPT_NAME# eq '#URLTAKENFROMDATABASE#'>selected</cfif>
     >#LINKNAME#</option
  </cfoutput>
</cfselect>

You can Group your query or your output to stick in sub headers within the drop down for example something like

<cfoutput query"get" group="SECTIONA">
  <option value="">#SECTIONA#</option>
      <cfoutput>
        <option value="#URLTAKENFROMDATABASE#"
        <cfif #CGI.SCRIPT_NAME# eq '#URLTAKENFROMDATABASE#'>selected</cfif>
         >#LINKNAME#</option
      </cfoutput>   
</cfouput>



回答4:


At the top of your page you could write a cfquery that would hit your database and retrieve the data. Then inside the page you can utilize the cfselect tag with its query attribute and this should populate the select box with values pulled from your cfquery.

This will allow your to quickly generate pages but it's not very reusable and is generally considered poor practice. I tend to stay away from any of the cfselect,cfform, etc tags. I also add my cfquery to a central .cfc file so they can be accessed throughout the site. This will save you time when the query changes and you are hunting throughout the site for where you made that specific call.

Anyway hope this helps, if you have any questions fire away!

---Edit---

In response to your updated question. You could have two cfquery tags on your page. One would fire on the first load of the page and populate the Province list. Upon selection this would submit a form and set a URL variable. You could then pass that variable to your second cfquery that would then populate the City list. The code sample provided by the user above me would work in this regard.

Again hope this helps, if you want specific code I can provide it but that logic should get you going on the right path.




回答5:


First, you can have your first dropdown bind to a cfc or populated from a query on your page, but not both. Either method will work, pick one.

Next, your Method function in your cfc has an argument but doesn't use it properly. Your cfquery should use it in the where clause. Also, don't try to pre-select any city. It doesn't make sense in the context of cascading selects.



来源:https://stackoverflow.com/questions/13414175/dynamic-drop-down-list-in-coldfusion-9

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!