草庐IT

javascript - 如何检查并返回数据直到没有匹配项?

coder 2024-12-31 原文

我创建了一个函数,它将在 JSON 文件中搜索不同的标签,如 [image] 和 [gallery] 等标签。如果匹配,它将返回并用新的输出替换它。像图像对象或幻灯片。

一个JSON对象可以包含多个相同类型的标签,也可以同时包含不同的标签。因此一个对象可以包含两个 [image] 标签,例如

JSON

http://snippi.com/s/bzrx3xi

问题是,如果找到多个 [image] 标签,它会被替换为相同的内容。我一直在寻找一个正在搜索标签的脚本,直到不再有匹配项为止。非常感谢@debatanu 提供的解决方案。

不幸的是,我对脚本有一些额外的希望,因为现在像图像这样的标签将被替换为 JSON 中媒体数组的最后一个图像对象,它只会获取并替换第一个标签。

我想知道是否可以检查每个标签并用新输出替换每个标签。

搜索标签

filterText: function(data) {

        // Loop through JSON data
        // Check if [tag] in data.text exists
        var dataText = data.text;
        var tags = {
            "gallery": /\[gallery\]/ig,
            "image": /\[image\]/ig
        };


        if (dataText != undefined) {
            var raw_data = dataText;

            for (var key in tags) {

                if (tags.hasOwnProperty(key)) {
                    var tag = tags[key];
                    var tagArr = [];

                    // Check if [tag] in data.text exists
                    while ( (tagArr = tag.exec(dataText)) !== null ) {

                        // Call functions
                        if (key == "gallery") { 
                            console.error('GALLERY');
                            parsedHTML = raw_data.replace(tagArr[0], shortcodeController.gallery(data));
                            raw_data = parsedHTML;
                            return parsedHTML;
                        }

                        if (key == "image") { 
                            console.error('IMAGE');
                            parsedHTML = raw_data.replace(tagArr[0], shortcodeController.image(data));
                            raw_data = parsedHTML;
                            return parsedHTML;
                            // model.find('p').html(parsedHTML);
                        }

                    }  

                }

            }
        };

调用filterText函数

getDataPopup: function(data) {

        if (data.text != undefined) {
            $('.js-popup .article').html(data.text);
            var parsed = dataController.filterText(data);
            console.log('parsed: ', parsed);
            $('.js-popup .article').html(parsed);
        } else {
            $('.js-popup .article').html(data.intro);
        }

    },

以上函数将在 while 循环内搜索标签。 这个脚本被调用,当用户点击一个项目时,将打开一个弹出屏幕。

当用户单击一个项目时,getDataPopup 函数调用的脚本将搜索匹配项,当找到匹配项时,它将调用函数 shortcodeController。 image(data) 将新输出返回给变量:parsedHTML

生成新输出的函数如下所示:

image: function(data) {

        // Development
        console.log('shortcodeController.image');

        var raw_data = data.text;
        var outputHTML;

        if (data.media != undefined) {

            for (var i = 0; i < data.media.length; i++) {

                if (data.media[i].image != undefined) {

                    outputHTML = '<div class="image">';

                    // Extract filename
                    var url = data.media[i].image.src;
                    var filename = url.substring( url.lastIndexOf('/') + 1, url.lastIndexOf('.') );
                    // console.log(filename);

                    outputHTML += '<img src="' + url + '" alt="' + filename + '" />';
                    //data.media[i].image = undefined;

                    outputHTML +='</div>';

                } 

            };

            return outputHTML;

        } else {
            // If media doesn't exists return empty string
            return '';
        }

    }, 

Debatanu 提到我应该在包含实际图像对象的 outputHTML 之后直接使用 data.media[i].image = undefined;,但这会导致未定义的错误。第一个 [image] 标签被替换为 undefined。当我注释掉这一行时,它将被媒体数组中的最后一个图像对象替换,如前所述。

也许它不能正常工作,因为 while 循环只查找图库和图像标签,如果匹配,则运行一次,因为他已经看到了标签。然后它将再次被调用,并用媒体数组中的第二个图像对象再次替换第一个图像标签。是否应该在 if 语句中添加一个 while 循环来判断它是画廊还是图像,以便为文本对象中的每个标签调用函数?

我还注意到,当我在控制台记录 tagArr 时,当我在 while 循环之后经过它时,它会给我一个 null 值,而当我在 [] 时,它会给我一个空数组创建数组后直接粘贴。除此之外,当我在 while 循环启动后直接控制台日志标签时,它只控制台日志标签一次,而在 JSON 中设置了两个图像标签。

最佳答案

您可以使用 exec 并使用

循环遍历它
    var dataText = data.text;
    var tags = {
        "gallery": /\[gallery\]/ig,
        "image": /\[image\]/ig,
    };

    if (dataText != undefined) {
         var raw_data = dataText;

        for (var key in tags) {
            if (tags.hasOwnProperty(key)) {
                var tag = tags[key];
                var arr=[];  


         while ((arr= tag.exec(dataText)) !== null) {   
                //arr[0] will contain the first match


                    //var newTag=newTags[key]; 
                    //you need to replace the matched output 
                    //so no need for newTag
                    if (key == "gallery") { 
                        console.error('GALLERY');
                        //replace the matched output arr[0]
                        //instead tag or newTag
                        //Since u have [] to replace we need to ommit the regex literal format /<<exp>>/
                        parsedHTML = raw_data.replace(arr[0], Triptube.shortcodeController.gallery(data));
                       //Need to add this line for reflecting the changed data
                        raw_data=parsedHTML;
                        model.find('p').html(parsedHTML);
                    }

                    if (key == "image") { 
                        console.error('IMAGE');
                        //replace the matched output arr[0]
                        //instead tag or newTag
                        //Since u have [] to replace we need to ommit the regex literal format /<<exp>>/
                        parsedHTML = raw_data.replace(arr[0], Triptube.shortcodeController.image(data));
                        console.log(parsedHTML);
                       //Need to add this line for reflecting the changed data
                        raw_data=parsedHTML;
                        model.find('p').html(parsedHTML);
                    }

                } 
            }
       }
    }

您可以在 MDN 中找到更多相关信息 在每个循环中,exec 都会为您提供下一个匹配项,直到没有匹配项为止。

编辑

我从一开始就添加了整个过滤器代码。您会看到 raw_data 变量应该在循环之前赋值。完成后,下面带有图像函数的代码应该会为您提供正确的结果。

编辑 2

首先 filterText 函数将在解析完 html 后返回解析后的 html

   filterText: function(data) {

    // Loop through JSON data
    // Check if [tag] in data.text exists
    var dataText = data.text;
    var tags = {
        "gallery": /\[gallery\]/ig,
        "image": /\[image\]/ig
    };


    if (dataText != undefined) {
        var raw_data = dataText,
        newData=JSON.parse(JSON.stringify(data));//Copy of the data object

        for (var key in tags) {

            if (tags.hasOwnProperty(key)) {
                var tag = tags[key];
                var tagArr = [];

                // Check if [tag] in data.text exists
                while ( (tagArr = tag.exec(dataText)) !== null ) {

                    // Call functions
                    if (key == "gallery") { 
                        console.error('GALLERY');
                        parsedHTML = raw_data.replace(tagArr[0], shortcodeController.gallery(newData));
                        raw_data = parsedHTML;
                        //return parsedHTML;
                    }

                    if (key == "image") { 
                        console.error('IMAGE');
                        parsedHTML = raw_data.replace(tagArr[0], shortcodeController.image(newData));
                        raw_data = parsedHTML;
                        //return parsedHTML; we will return the parsed HTML only when all the tags have been replaced
                        // model.find('p').html(parsedHTML);
                    }

                }  

            }

        }
       return parsedHTML; //return the parsed HTML here
    };

接下来是 image 函数,它将解析图像,

      image: function(data) {

    // Development
    console.log('shortcodeController.image');

    var raw_data = data.text;
    var outputHTML;

    if (data.media != undefined) {

        for (var i = 0; i < data.media.length; i++) {

            if (data.media[i].image != undefined) {

                outputHTML = '<div class="image">';

                // Extract filename
                var url = data.media[i].image.src;
                var filename = url.substring( url.lastIndexOf('/') + 1, url.lastIndexOf('.') );
                // console.log(filename);

                outputHTML += '<img src="' + url + '" alt="' + filename + '" />';
                outputHTML +='</div>';
                data.media[i].image = undefined;
                //Uncommented the above code, because now the operation will be done on the copy of the original data object



            } 

        };

        return outputHTML;

    } else {
        // If media doesn't exists return empty string
        return '';
    }

}

关于javascript - 如何检查并返回数据直到没有匹配项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33934181/

有关javascript - 如何检查并返回数据直到没有匹配项?的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  4. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  5. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  6. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  7. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  8. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  9. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

    我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

  10. ruby - 如何每月在 Heroku 运行一次 Scheduler 插件? - 2

    在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/

随机推荐