1

I have the following function:

Updated: added return to $.ajax

searchAjax({url = 'app/php/check.php', data}: {url: any, data: any}): any 
{   
    return $.ajax({
        url: url,
        type: 'post',
        dataType: 'text', 
        data: { data },
        success: function (return_data)
        {   
            return String(return_data);
        },  
        error: function (xhr, status, error) 
        {   
            var err = eval("(" + xhr.responseText + ")");
            console.log(err.Message);
            return err.Message;
        }   
    }); 
}

For now, check.php returns echo 'hi'. Just for testing, I'm trying to console.log the response (in this case return_data). However I get the error EXCEPTION: hi is not defined when I try to console.log it.

Update: Now I get an object with a bunch of stuff and responseText which contains the actual response.

9
  • 1
    You've tagged this Angular2 any reason why you don't use the @angular/http for such requests. Commented Dec 13, 2016 at 23:46
  • 1
    @JJB May be he has some legacy code that needs to rewrite to Angular2? Commented Dec 13, 2016 at 23:49
  • 1
    @RomanC That's why I ask because if it's just that request and he's using jQuery just for that, then in reality he should be using @angular/http. Commented Dec 13, 2016 at 23:52
  • @JJB Good point, maybe I should try out http Commented Dec 14, 2016 at 0:00
  • @JJB Angular allows to use any javascript library, including jQuery, which was very popular before, and can't solve the problem with the code above. Commented Dec 14, 2016 at 0:01

2 Answers 2

1

Sounds like your eval isn't getting the text you think it's getting. I believe your result: "echo 'hi'" is stripping the apostrophe so you're actually evaluating "echo hi". This can be an ajax client issue. Or your API is stripping it. Check to see what your browser is receiving from the API.

Also, echo isn't in native javascript

Sign up to request clarification or add additional context in comments.

3 Comments

echo "hi" is php, so what's getting returns is just hi. I think I may have worked it out a little, but I think I might try http suggested by others.
Then you actually are evaluating "hi" which is not defined. What you probably wanted to do is eval console.log("hi"), basically the text printed by the API response in quotes, if you wanted to see the results in console.
It was mainly because I did not do a proper return. Now I updated it with a return, it returns me an object with the response text, but I can't seem to extract it. I know that you can do it in the success function of the ajax, but I'll probably look at angular's http instead.
0

Answering a bit too late. You are not printing the response. You are trying to evaluate the response as a javascript expression. During evaluation, javascript doesn't see 'echo hi' as a valid javascript string and generates the error 'hi is not defined'. And then you are not printing the ajax response itself. You are printing the evaluation result which obviously is a failure in evaluation. You can print the response by writing: console.log(xhr.response);

Comments

Your Answer

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.