我有一个购物车,在下拉菜单中显示产品选项,如果他们选择“是”,我想使页面上的一些其他字段可见。

问题是购物车还在文本中包含价格修饰符,每个产品的价格修饰符可能不同。下面的代码工作:

$(document).ready(function() {
    $('select[id="Engraving"]').change(function() {
        var str = $('select[id="Engraving"] option:selected').text();
        if (str == "Yes (+ $6.95)") {
            $('.engraving').show();
        } else {
            $('.engraving').hide();
        }
    });
});

然而,我宁愿使用这样的东西,这是行不通的:

$(document).ready(function() {
    $('select[id="Engraving"]').change(function() {
        var str = $('select[id="Engraving"] option:selected').text();
        if (str *= "Yes") {
            $('.engraving').show();
        } else {
            $('.engraving').hide();
        }
    });
});

我只想在所选选项包含单词“Yes”时执行该操作,并忽略价格修饰符。


当前回答

现在写这个答案有点晚了,但我还是想把它写进去。字符串。原型现在有一个方法includes,可以检查子字符串。该方法区分大小写。

var str = 'It was a good date';
console.log(str.includes('good')); // shows true
console.log(str.includes('Good')); // shows false

要检查子字符串,可以采用以下方法:

if (mainString.toLowerCase().includes(substringToCheck.toLowerCase())) {
    // mainString contains substringToCheck
}

查看文档了解更多信息。

其他回答

是这样的:

if (str.indexOf("Yes") >= 0)

...或者你可以使用波浪号操作符:

if (~str.indexOf("Yes"))

这是因为如果根本没有找到字符串,indexOf()将返回-1。

注意,这是区分大小写的。 如果你想要一个不区分大小写的搜索,你可以写

if (str.toLowerCase().indexOf("yes") >= 0)

Or:

if (/yes/i.test(str))

后者是正则表达式或正则表达式。

正则表达式分解:

/表示这是正则表达式 Yes表示正则表达式将以正确的顺序找到那些正确的字符 /结束正则表达式 我将正则表达式设置为不区分大小写 .test(str)确定正则表达式是否匹配str 总而言之,这意味着它将查看是否能在变量str中以不区分大小写的确切顺序找到字母y、e和s

如果你能使用库,你会发现Lo-Dash JS库是非常有用的。在这种情况下,继续检查_.contains()(从v4开始被_.includes()取代)。

(注意Lo-Dash约定将库对象命名为_。 不要忘记在同一页面中检查安装,为您的项目设置它。)

_.contains("foo", "oo");     // → true
_.contains("foo", "bar");    // → false
// Equivalent with:
_("foo").contains("oo");     // → true
_("foo").contains("bar");    // → false

在你的情况下,继续使用:

_.contains(str, "Yes");
// or:
_(str).contains("Yes");

..你更喜欢哪一个。

你可以使用搜索或匹配。

str.search('Yes')

将返回匹配的位置,如果没有找到则返回-1。

ECMAScript 6引入了String.prototype。包含,以前命名为包含。

它可以这样使用:

'foobar'.includes('foo'); // true
'foobar'.includes('baz'); // false

它还接受一个可选的第二个参数,用于指定开始搜索的位置:

'foobar'.includes('foo', 1); // false
'foobar'.includes('bar', 1); // true

它可以被填充以使其在旧浏览器上工作。

您可以定义一个扩展方法并在以后使用它。

String.prototype.contains = function(it) 
{ 
   return this.indexOf(it) != -1; 
};

这样你就可以在页面的任何地方使用:

var str="hello how are you";
str.contains("are");

返回true。

有关更多扩展助手方法,请参阅下面的帖子。 Javascript帮助方法