0

I know this question has been asked before but I have tried numerous solutions from stackoverflow and I could not find the problem.I receive the error in the browser console that the function that I defined in the script tag is not defined.This is the code:

<html>
<body>
 <input type="text" id="input_1"/>
 <button type="button" value="Click" onclick="cd()" id="getDatabaseData">Click!</button>
 <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js">
 function cd() {
 var inbtn = {};
 inbtn.input = $('#input_1').val();
 console.log('Started...');
 $.ajax({
 type: 'post',
 url: '<%: Url.Action("Trial") %>',
 data: inbtn,
 success: function er() {
 console.log("Succes!")
 },
 error: function err() {
 console.log("Error!")
 }
 })
 } 
 </script>
</body>
</html>

I tried to add $document.ready and also to add a separate event listener(not onclick function)

 $(document).ready(
 document.getElementById("getDatabaseData").addEventListener("click", cd, false));

It did not worked.I also replaced the whole function with a simple function:

function cd(){
console.log("Message");
}

and I still receive the same error:

Uncaught ReferenceError: cd is not defined
 at HTMLButtonElement.onclick
asked Dec 21, 2019 at 17:28
1
  • 1
    Your cd() function is not correctly placed within a <script> tag in your document. Open a new <script> after your jQuery. Commented Dec 21, 2019 at 17:33

2 Answers 2

2

To clarify what has already been said, but not specifically called out... a script tag can EITHER contain a src attribute to pull in an external script file OR it can contains the script content. A single script tag cannot contain both.

answered Dec 21, 2019 at 17:44
Sign up to request clarification or add additional context in comments.

Comments

1

Just a small mistake

You need to make another script tag and put the function cd inside

<html>
<body>
 <input type="text" id="input_1"/>
 <button type="button" value="Click" onclick="cd()" id="getDatabaseData">Click!</button>
 <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js">
 </script>
 <script>
 function cd() {
 var inbtn = {};
 inbtn.input = $('#input_1').val();
 console.log('Started...');
 $.ajax({
 type: 'post',
 url: '<%: Url.Action("Trial") %>',
 data: inbtn,
 success: function er() {
 console.log("Succes!")
 },
 error: function err() {
 console.log("Error!")
 }
 })
 } 
 </script>
</body>
</html>

I am assuming this is the result you want , because the cd is now defined

enter image description here

answered Dec 21, 2019 at 17:32

Comments

Your Answer

Draft saved
Draft discarded

Sign up or log in

Sign up using Google
Sign up using Email and Password

Post as a guest

Required, but never shown

Post as a guest

Required, but never shown

By clicking "Post Your Answer", you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.