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

标签 javascript jquery json

我创建了一个函数,它将在 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 - 客户端项目在端口 x 上运行,服务器 api 端点在端口 y 上运行。 AJAX如何知道webapi端点在哪里

javascript - 滑动时防止触摸启动

java - java中如何使用Gson读取Json

javascript - 如何创建更改网页字体的 Javascript/JSON 脚本

javascript - 将 'no-cors' 模式与获取 API 一起使用时,请求 header 未按预期设置

javascript - Xul:用垂直盒子动态填充水平盒子会导致元素垂直放置

javascript - 触发 JavaScript 的简单 URL

javascript - 对象、数组和 $.each()

python - json.解码器.JSONDecodeError : Extra data: line 2 column 1 (char 190)

javascript - 如何停止在 Internet Explorer 11 中打开多个选项卡