javascript - 更改列表中的文本

标签 javascript jquery list html-lists pinnacle-cart

我的全新 14 day Pinnacle cart free trial 有两个类别有两个类别(威尔士语和英语):

"Llyfrau [Books]"

"Anrhegion [Gifts]"

我需要一个函数来删除不需要的语言。我让它适用于产品描述,但不适用于类别。

我正在威尔士语中

"ANRHEGION"

"ANRHEGION"

英文:

"GIFTS"

"GIFTS"

这是不完全存在的代码!我认为这就是我所说的不太正确的函数 - .panel-catalog-categories .content ul li a span ???

编辑 - 这是我从全新安装中添加的所有代码:

{if $current_language.language_id == "1"}

  {literal}

  <script type="text/javascript">

   (function($,h,c){var a=$([]),e=$.resize=$.extend($.resize,{}),i,k="setTimeout",j="resize",d=j+"-special-event",b="delay",f="throttleWindow";e[b]=250;e[f]=true;$.event.special[j]={setup:function(){if(!e[f]&&this[k]){return false}var l=$(this);a=a.add(l);$.data(this,d,{w:l.width(),h:l.height()});if(a.length===1){g()}},teardown:function(){if(!e[f]&&this[k]){return false}var l=$(this);a=a.not(l);l.removeData(d);if(!a.length){clearTimeout(i)}},add:function(l){if(!e[f]&&this[k]){return false}var n;function m(s,o,p){var q=$(this),r=$.data(this,d);r.w=o!==c?o:q.width();r.h=p!==c?p:q.height();n.apply(this,arguments)}if($.isFunction(l)){n=l;return m}else{n=l.handler;l.handler=m}}};function g(){i=h[k](function(){a.each(function(){var n=$(this),m=n.width(),l=n.height(),o=$.data(this,d);if(m!==o.w||l!==o.h){n.trigger(j,[o.w=m,o.h=l])}});g()},e[b])}})(jQuery,this);

   jQuery(document).ready(function()

   {

     //call remove brackets if english
      // Product page- Common
      // Description .page-product .product-description

     displayEnglish(".product-description .product-page-block-content");


      // .catalog-product-title"); ???
      // .panel-catalog-categories .title  ????
      displayEnglish(".panel-catalog-categories .content ul li a span");

      //function to select english

      function displayEnglish(text_selector) {
        if($(text_selector).length> 0) {
          var english_text = $(text_selector).text().match(/\[([^/]]+)\]/g);
          jQuery(text_selector).text(english_text[0].slice(1, -1));
      }
    }

   });

  </script>

  {/literal}

  {else}

  {literal}

  <script type="text/javascript">

   (function($,h,c){var a=$([]),e=$.resize=$.extend($.resize,{}),i,k="setTimeout",j="resize",d=j+"-special-event",b="delay",f="throttleWindow";e[b]=250;e[f]=true;$.event.special[j]={setup:function(){if(!e[f]&&this[k]){return false}var l=$(this);a=a.add(l);$.data(this,d,{w:l.width(),h:l.height()});if(a.length===1){g()}},teardown:function(){if(!e[f]&&this[k]){return false}var l=$(this);a=a.not(l);l.removeData(d);if(!a.length){clearTimeout(i)}},add:function(l){if(!e[f]&&this[k]){return false}var n;function m(s,o,p){var q=$(this),r=$.data(this,d);r.w=o!==c?o:q.width();r.h=p!==c?p:q.height();n.apply(this,arguments)}if($.isFunction(l)){n=l;return m}else{n=l.handler;l.handler=m}}};function g(){i=h[k](function(){a.each(function(){var n=$(this),m=n.width(),l=n.height(),o=$.data(this,d);if(m!==o.w||l!==o.h){n.trigger(j,[o.w=m,o.h=l])}});g()},e[b])}})(jQuery,this);

    jQuery(document).ready(function()

    {

      //call remove brackets if english

      displayWelsh(".product-description .product-page-block-content");

      displayWelsh(".panel-catalog-categories .content ul li a span");
      //function to select welsh

      function displayWelsh(text_selector) {
        if($(text_selector).length> 0) {
          var welsh_text = $(text_selector).text().replace(/\[([^/]]+)\]/g, "");

          jQuery(text_selector).text(welsh_text);
      }
    }

   });

  </script>

  {/literal}

{/if}

最佳答案

您的 displayEnglish 函数中的正则表达式看起来错误 - 您有:

\[([^}]+)\]

它匹配开头的[,然后找到最长的可能的不是}的字符,然后是结尾的]

可能否定字符集中的 } 是一个拼写错误,您的意思是 ]

<小时/>

以非常快速的 Firebug session 为例

// existing
> "Anrhegion [Gifts] Llyfrau [Books]".match(/\[([^}]+)\]/g);
["[Gifts] Llyfrau [Books]"]

// fixed
> "Anrhegion [Gifts] Llyfrau [Books]".match(/\[([^\]]+)\]/g);
["[Gifts]", "[Books]"]

关于javascript - 更改列表中的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12802503/

相关文章:

javascript - 如何添加一个计数器来显示找到了多少文本匹配项

JavaScript 在按钮单击时将用户输入存储在数组中

javascript - jquery 复选框 - 检查数组中的值并检查这些值

jquery - 如何始终显示两个日期选择器并在输入中设置默认日期

c# - 如何使用给定名称 List<string> 初始化多个 List<string>

javascript - 如何使用 Babel 和 Grunt 正确编译项目

javascript - 通过 exec 将变量传递给 PhantomJS

javascript - Jquery 代码破坏页面 Javascript

list - 在 F# 中将列表拆分为两个相等的列表

python - 列表的正常循环和使用切片之间的区别?