Solved

get service from javascript function

Posted on 2011-03-07
8
279 Views
Last Modified: 2012-06-21
I am trying to design a service that works with the onkeyup instead of the regular asp.textbox changed event.  the following is what I have but I do not know how to conenct the javascript function to the service and get the textbox information.
<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" Runat="Server">
    <script language="javascript" type="text/javascript">
        function getnames() {
            var theName = document.getElementById("txtadmin")
        }
    </script>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="BodyContent" Runat="Server">
   
    <table width="100%">
        <tr>
            <td style="height:20px"></td>
        </tr>
        <tr>
            <td align="center">Add Admin:&nbsp;&nbsp;&nbsp;<asp:TextBox ID="txtAdmin" runat="server" Width="260" AutoPostBack="true" 
            AutoCompleteType="DisplayName" onkeyup="javascript:getNames();" />
            <asp:AutoCompleteExtender ID="txtAdmin_AutoCompleteExtender" runat="server" Enabled="True" TargetControlID="txtAdmin" 
            ServiceMethod="FindName" MinimumPrefixLength="0" />
            <asp:TextBoxWatermarkExtender ID="txtAdmin_TextBoxWatermarkExtender" runat="server" Enabled="True" TargetControlID="txtAdmin" 
            WatermarkText="Enter LastName First"/>
            </td>
        </tr>
    </table>
   
</asp:Content>



Partial Class Admin_test
    Inherits System.Web.UI.Page
    <System.Web.Services.WebMethod()> _
    <System.Web.Script.Services.ScriptMethod()> _
    Public Shared Function Findname(ByVal prefixText As String, ByVal count As String) As String()
        Return New AutoComplete().FindName(prefixText, count)
    End Function

    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
        txtAdmin.Attributes.Add("onKeyup", "javascript(getnames();")
    End Sub
End Class

Open in new window

0
Comment
Question by:kdeutsch
  • 5
  • 3
8 Comments
 
LVL 35

Expert Comment

by:Miguel Oz
ID: 35062321
Change:
txtAdmin.Attributes.Add("onKeyup", "javascript(getnames();"
to
txtAdmin.Attributes.Add("onKeyup", "getnames()")

Note: Your javascript code is not fully implemented yet, but I suppose you want the above part working.

0
 

Author Comment

by:kdeutsch
ID: 35070010
Ok changed this, but now its giving me an error on my javscript on the sendrequest.

<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" Runat="Server">
    <script language="javascript" type="text/javascript">
        function SendRequest() {
            AutoComplete.FindName('<%=txtAdmin.ClientID%>').value

        function OnComplete(arg) {
            alert(arg)
        }
    </script>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="BodyContent" Runat="Server">
   
    <table width="100%">
        <tr>
            <td style="height:20px"></td>
        </tr>
        <tr>
            <td align="center">Add Admin:&nbsp;&nbsp;&nbsp;<asp:TextBox ID="txtAdmin" runat="server" Width="260" AutoPostBack="true"
            AutoCompleteType="DisplayName" />
            <asp:AutoCompleteExtender ID="txtAdmin_AutoCompleteExtender" runat="server" Enabled="True" TargetControlID="txtAdmin"
            ServiceMethod="FindName" MinimumPrefixLength="0" />
            <asp:TextBoxWatermarkExtender ID="txtAdmin_TextBoxWatermarkExtender" runat="server" Enabled="True" TargetControlID="txtAdmin"
            WatermarkText="Enter LastName First"/>
            </td>
        </tr>
    </table>
   
</asp:Content>
0
 
LVL 35

Expert Comment

by:Miguel Oz
ID: 35074245
Glad to solve your question.
Regarding your post question on js implementation. Please post the exact error message and any reference code that you are using to implement this service.
0
 

Author Comment

by:kdeutsch
ID: 35085540
Hi,

It throws an error when i start to type in the textbox and gives me
Object expected and it highlights the SendRequest of the onkeyup

this is my code behind
 Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
        txtAdmin.Attributes.Add("onKeyup", "SendRequest()")
    End Sub


HTML
<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" Runat="Server">
    <script language="javascript" type="text/javascript">
        function SendRequest() {
            AutoComplete.FindName('<%=txtAdmin.ClientID%>').value

        function OnComplete(arg) {
            alert(arg)
        }
    </script>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="BodyContent" Runat="Server">
   
    <table width="100%">
        <tr>
            <td style="height:20px"></td>
        </tr>
        <tr>
            <td align="center">Add Admin:&nbsp;&nbsp;&nbsp;<asp:TextBox ID="txtAdmin" runat="server" Width="260" AutoPostBack="true"
            AutoCompleteType="DisplayName" />
            <asp:AutoCompleteExtender ID="txtAdmin_AutoCompleteExtender" runat="server" Enabled="True" TargetControlID="txtAdmin"
            ServiceMethod="FindName" MinimumPrefixLength="0" />
            <asp:TextBoxWatermarkExtender ID="txtAdmin_TextBoxWatermarkExtender" runat="server" Enabled="True" TargetControlID="txtAdmin"
            WatermarkText="Enter LastName First"/>
            </td>
        </tr>
    </table>
   
</asp:Content>
0
How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

 

Author Comment

by:kdeutsch
ID: 35085561
The service sits on a code behind page in my APp_code folder called autoComplete.vb which goes through a autocomplete.asmx file.

Imports System.Web
Imports System.Web.Services
Imports System.Web.Services.Protocols
Imports ReadinessCommon
Imports System.Data
Imports System.Data.SqlClient


' To allow this Web Service to be called from script, using ASP.NET AJAX, uncomment the following line.
<System.Web.Script.Services.ScriptService()> _
<WebService(Namespace:="http://tempuri.org/")> _
<WebServiceBinding(ConformsTo:=WsiProfiles.BasicProfile1_1)> _
<Global.Microsoft.VisualBasic.CompilerServices.DesignerGenerated()> _
Public Class AutoComplete
    Inherits System.Web.Services.WebService

    <WebMethod()> _
    Public Function FindName(ByVal prefixText As String, ByVal count As String) As String()
        Dim items As New List(Of String)

        sql = "SELECT strFullname FROM WorsDotNet.dbo.tblUser WHERE strFullName like '%" & prefixText & "%' ORDER BY strFullName ASC"

        myDataTable = New DataTable
        myDataTable = getData(sql)

        If myDataTable.Rows.Count > 0 Then
            For Each dRow As DataRow In myDataTable.Rows
                items.Add(dRow(0).ToString)
            Next
        End If

        Return items.ToArray
    End Function
0
 
LVL 35

Accepted Solution

by:
Miguel Oz earned 500 total points
ID: 35090151
Uhmm, I will change code as follows:
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
        txtAdmin.Attributes.Add("onKeyup", "SendRequest(this)")
    End Sub


HTML
<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" Runat="Server">
    <script language="javascript" type="text/javascript">
        function SendRequest(txtObj) {
           var results = AutoComplete.FindName(txtObj.id);
//Consume results if (results != null) then use it.
        }
    </script>
</asp:Content>
//All other code remain the same

Note: I notice that you are missing the scriptmanager in your html markup
<asp:ScriptManager ID="ScriptManager1" runat="server"
EnablePageMethods = "true">
Any AJAX page requires it, otherwise js may not work properly.

0
 

Author Comment

by:kdeutsch
ID: 35094578
mas_oz2003:

The script manager sits in my sitemaster along with all the service requests, its easier than to put on every page.

Ok getting a bunch more errors, but the errors are ones I think I can handle.
0
 

Author Closing Comment

by:kdeutsch
ID: 35094594
thanks
0

Featured Post

How to improve team productivity

Quip adds documents, spreadsheets, and tasklists to your Slack experience
- Elevate ideas to Quip docs
- Share Quip docs in Slack
- Get notified of changes to your docs
- Available on iOS/Android/Desktop/Web
- Online/Offline

Join & Write a Comment

The ECB site provides FX rates for major currencies since its inception in 1999 in the form of an XML feed. The files have the following format (reducted for brevity) (CODE) There are three files available HERE (http://www.ecb.europa.eu/stats/exch…
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

747 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now