SyntaxError:未终止的字符串文字javascript控制台

时间:2017-01-11 05:11:53

标签: javascript jquery html ajax

我正在创建一个Javasript对象:

var obj= new Object();
obj.Message = $(".textarea").val();

并通过JSON stringify发布此对象:

$.ajax({
    type: "POST",
    contentType: "application/json",
    dataType: "json",
    url: 'xx/yy',
    data: JSON.stringify(obj),
    success: function (html) {
        // ...
    },
    error: function (request, status, error) {
        // ...           
    }
});

我得到了:

  

SyntaxError:控制台中未终止的字符串文字

我应该替换什么?

修改

此问题特定于用户在纯文本区域(非富文本区域)中输入的数据

2 个答案:

答案 0 :(得分:0)

这可能是你有一些换行符或一些无效的字符串文字的价值。您可以像这样替换textarea值的换行符。

var str = $('#textarea1').val();
str = str.replace(/(?:\r\n|\r|\n)/g, ''); 

这是完整的代码段,因此您可以检查。希望您在执行JSON.stringify(obj)时可以逃避“SyntaxError:unterminated string literal”。

<!DOCTYPE html>
<html>
	<head>
		<script src="http://code.jquery.com/jquery-1.8.3.js"></script>
	</head>
	<body>
		<textarea id="textarea1" rows="4" cols="50">
		</textarea>
		<input type="button" value="Check" id="btnCheck"/>
		
		<script>
			$(document).ready(function(){
			
				$('#btnCheck').on('click',function(){
				
					var str = $('#textarea1').val();
					str = str.replace(/(?:\r\n|\r|\n)/g, ''); 
					var obj= new Object();
					obj.Message = str;
					
					console.log(JSON.stringify(obj));
					
				});
			});
		</script>
	</body>
	
	
</html>

答案 1 :(得分:0)

使用模板字面量``,ECMAScript 2015 环境支持这些内容

相关问题