语法错误,无法识别的表达式:option [value = property name]

时间:2015-01-28 17:28:06

标签: javascript jquery datalist

我有一个看起来像这样的数据列表

<datalist id="properties">
       <option value="property name"></option>
       <option value="property"></option>
</datalist>

现在我使用此代码查找用户输入的值在列表中的位置:

var user_property = $('#user_property').val().toLowerCase(); // taken from input type with id user_property
var pro = $('#properties').find("option[value="+user_property.replace(' ','-')+"]");
if(pro != null && pro.length > 0)
{
    // run some code
}
else
{
    // show error popup
}

我在var pro = $('#properties').find("option[value="+user_property.replace(' ','-')+"]");

收到错误

错误代码显示Syntax error, unrecognized expression: option[value=property name]

如何摆脱这个错误?

3 个答案:

答案 0 :(得分:10)

尝试添加引号,如:

var pro = $('#properties').find("option[value='"+user_property.replace(' ','-')+"']");

或更好地将其分解为:

var replaced = user_property.replace(' ','-');
var pro = $('#properties').find("option[value='"+replaced+"']");

如果你想检查“属性名称”这样的文字,那么你可以直接做:

var pro = $('#properties').find("option[value='"+user_property+"']");

答案 1 :(得分:1)

尝试在值周围添加引号,它将起作用。

$('#properties').find("option[value='property name']")

答案 2 :(得分:1)

您需要为您的值添加单引号,例如

var pro = $('#properties').find("option[value='"+user_property.replace(' ','-')+"']");