【问题标题】:Uncaught SyntaxError: Unexpected token ILLEGALUncaught SyntaxError: Unexpected token ILLEGAL
【发布时间】:2012-11-20 03:12:53
【问题描述】:

我遇到了类似的问题: Uncaught SyntaxError: Unexpected Token - jQuery - Help!

我正在使用 CakePHP 2.x 生成一个 jquery AJAX 请求。它在我的本地设置上运行良好,但在生产服务器上失败,给我一个未捕获的 SyntaxError:

Uncaught SyntaxError: Unexpected token ILLEGAL

这是PHP:

// Get the select element by its generated id attribute.
echo $this->Js->get('#'.$equipment_code)->event(
    // Change in the dropdown selection
    'change',
    // Request an array of compatible brands (match model type)
    $this->Js->request(
        array('controller'=>'builds','action'=>'ajax_brands'),
        // Update the associated brand dropdown
        array('update' => $hashed_brand_code, 'dataExpression' => true, 'data' => '$("#'.$equipment_code.'").serialize()')
    )
);

生成此脚本:

<script type="text/javascript">
//<![CDATA[
$(document).ready(function () {
    $("#equipment-14-0").bind("change", function (event) {
        $.ajax({
            data:$("#equipment-14-0").serialize(), 
            dataType:"html", 
            success:function (data, textStatus) {
                $("#brand-14-0").html(data);}, 
                url:"\/proj\/eztek-dev\/builds\/ajax_brands"
            });
            return false;
        });
    $("#brand-14-0").bind("change", function (event) {
        $.ajax({
            data:$("#brand-14-0,#equipment-14-0").serialize(),
            dataType:"html", 
            success:function (data, textStatus) {
                $("#model-14-0").html(data);
            }, 
            url:"\/proj\/eztek-dev\/builds\/ajax_models"
        });
        return false;
    });
    $("#equipment-14-2").bind("change", function (event) {
        $.ajax({
            data:$("#equipment-14-2").serialize(), 
            dataType:"html", 
            success:function (data, textStatus) {
                $("#brand-14-2").html(data);
            }, 
            url:"\/proj\/eztek-dev\/builds\/ajax_brands"
        });
        return false;
    });
    $("#brand-14-2").bind("change", function (event) {
        $.ajax({
            data:$("#brand-14-2,#equipment-14-2").serialize(), 
            dataType:"html", 
            success:function (data, textStatus) {
                $("#model-14-2").html(data);
            }, 
            url:"\/proj\/eztek-dev\/builds\/ajax_models"
        });
        return false;});
    });
//]]>
</script>

这里是

非常感谢您提供的任何帮助,如果有任何其他有用的信息,请告诉我,我会尽快放在这里。

谢谢!

编辑:

感谢大家的帮助。我已通过删除 js 文件中未接受的字符来修复未捕获的语法错误,但 AJAX 仍然无法在生产服务器上运行。我在控制台中收到以下错误:

Failed to load resource: the server responded with a status of 500 (Internal Server Error) 
{Domain name} /proj/eztek-dev/builds/ajax_brands?data%5BEzcomponent%5D%5B2%5D%5Bezmodel_type_id%5D=5


(来源:resaraos.com

serialize() 会不会有问题?

【问题讨论】:

  • 禁用所有Chrome扩展,然后一一重新启用,看看是哪个扩展导致了错误。
  • 您的本地服务器和生产服务器的操作系统是什么?您的应用在本地和生产服务器中的相对路径是什么?
  • 你确定你输入的 URL 是正确的吗,这是一个 linux 服务器。
  • Rob W - 在禁用所有 chrome 扩展的情况下,脚本仍然失败,我在 Safari 和 Firefox 中遇到相同的情况,尽管如此,您认为扩展可能会导致错误吗?谢谢!
  • sємsєм - 它们在两种情况下都不同:本地服务器是 OSX 10.6,相对 url 为 /eztek-dev/ 生产服务器是 Debian,相对 url 为 /proj/eztek-dev/ 谢谢!

标签: php javascript jquery cakephp-2.1


【解决方案1】:

对遇到此问题的任何人的迟到提示:

Chrome 未指定此特定错误。使用 Firefox(Firebug 控制台)获取有关错误的更多信息。

【讨论】:

    【解决方案2】:

    我只想指出,您生成 php 代码的方式非常不切实际。

    $arr1 = array(
        'controller'=>'builds',
        'action'=>'ajax_brands'
    );
    
    $arr2 = array(
        'update' => $hashed_brand_code, 
        'dataExpression' => true, 
        'data' => '$("#'.$equipment_code.'").serialize()'
    );
    
    $jsRequest = $this->Js->request($arr1, $arr2);
    $jsGet = $this->Js->get('#'.$equipment_code)->event('change', $jsRequest); // Change in the dropdown selection & update the associated brand dropdown
    
    $echo $jsGet;
    

    类似的东西是有道理的。

    很抱歉回答了一个旧帖子(没有真正回答问题的真实答案),这真的刺穿了我的眼睛。

    【讨论】:

      猜你喜欢
      • 2012-01-30
      • 2011-12-01
      • 1970-01-01
      • 1970-01-01
      • 2012-09-12
      • 2012-09-22
      • 1970-01-01
      • 2013-06-19
      相关资源
      最近更新 更多