如何修复包含动态输入字段的代码?

How can I fix my code containing a dynamic input field?

提问人:GelS Sy 提问时间:5/10/2019 最后编辑:GelS Sy 更新时间:6/1/2020 访问量:65

问:

我是jQuery的新手,不能完全理解它。我只是从我的 php 文件中复制了这段代码并将其放在那里。

这是我在php中的代码:

        <div class="form-row" id="dynamic_field">
            <div class="input-group">
                <input type="text" class="form-control" name="lname" placeholder ="Last Name" required>
                <input type="text" class="form-control" name="fname" placeholder ="First Name" required>
                <input type="text" class="form-control" name="mname" placeholder ="Middle Name">
                <select class="form-control" name="gender" required>
                    <option value="">Gender</option>
                    <option value="Male">Male</option>
                    <option value="Female">Female</option>
                </select>
                <br>
                &nbsp;Semester Started:
                <select class="form-control" name="semenrolled1" required>
                    <option>Select Semester</option>
                    <?php
                        $query5 = "select distinct(term_name) from term";
                        $rsf5 = mysql_query($query5);
                        while($row5 = mysql_fetch_array($rsf5)){
                    ?>
                    <option>
                        <?php 
                            if($row5['term_name']!=' '){
                                echo $row5['term_name'];
                            } 
                        ?>
                    </option>
                    <?php
                        }
                    ?>
                </select>
                <input type="text" class="form-control" name="acadyear1" placeholder ="Acad Year" required>
                <span class="input-group-addon">
                    <button type="button" name="dynamic_add" id="dynamic_add" class="btn btn-primary btn-save" style="background-color:#0066ff;" >
                            <span class="glyphicon glyphicon-plus" ></span>
                    </button>
                </span>
            </div>
        </div>

这是我的动态输入字段代码:

    $(document).ready(function(){
        var i = 1;
        $('#dynamic_add').click(function(){
            i++;
            $('#dynamic_field').append('<div class="form-row" id="row'+i+'"><div class="input-group"><input type="text" class="form-control" name="lname" placeholder ="Last Name" required><input type="text" class="form-control" name="fname" placeholder ="First Name" required><input type="text" class="form-control" name="mname" placeholder ="Middle Name"><select class="form-control" name="gender" required><option value="">Gender</option><option value="Male">Male</option><option value="Female">Female</option></select><br>&nbsp;Semester Started:<select class="form-control" name="semenrolled1" required><option>Select Semester</option><?php$query5 = "select distinct(term_name) from term";$rsf5 = mysql_query($query5);while($row5 = mysql_fetch_array($rsf5)){?><option><?php if($row5['term_name']!=' '){echo $row5['term_name'];} ?></option><?php}?></select><input type="text" class="form-control" name="acadyear1" placeholder ="Acad Year" required><span class="input-group-addon"><button name="remove" id="'+i+'" class="btn btn-danger btn_remove"><span class="glyphicon glyphicon-plus" ></span></button></span></div></div>');
        });

        $(document).on('click','.btn_remove', function(){
            var button_id = $(this).attr("id");
            $("#row"+button_id+"").remove();
        });
    });

错误显示“解析错误”,我不知道该怎么办。

PHP jQuery

评论

0赞 Shudhansh Shekhar 5/10/2019
您是否将jQuery脚本包含在同一个PHP文件中?
0赞 GelS Sy 5/10/2019
是的,它们在同一个文件中。
0赞 empiric 5/10/2019
您通过 JS 将 PHP 代码附加到 html 中,这永远不会起作用。PHP 仅在服务器端执行,而您使用 JS 所做的更改仅在客户端执行:请参阅:服务器端和客户端之间的差异
0赞 Shudhansh Shekhar 5/10/2019
@empiric,不,你错了。如果 JS 包含在 PHP 文件中,则可以在 JS 代码中使用 PHP。
0赞 empiric 5/10/2019
@ShudhanshShekhar是的,除非,但是从这个问题中不清楚JS代码在PHP文件中,至少对我来说是这样

答:

1赞 Shudhansh Shekhar 5/10/2019 #1

您的问题是由多种原因引起的。

  1. 字符串之间没有正确的连接。

  2. PHP 中的语法不正确,例如 .始终在 PHP 开始标记后提供一个空格,例如 .<?php$query5<?php $query5

  3. 虽然单行代码有时似乎很好,但始终尝试将重点放在代码的可读性上,并编写耗行(永远)、整洁和清晰的代码。

使用以下代码。

$(document).ready(function(){
        var i = 1;
        $('#dynamic_add').click(function(){
            i++;
            let terms = "<?php 
                $query5 = "select distinct(term_name) from term";
                $rsf5 = mysql_query($query5); 
                while($row5 = mysql_fetch_array($rsf5)){
                    echo '<option>';
                    if($row5['term_name'] != ''){ echo $row5['term_name']; }
                    echo '</option>';
                } 
            ?>";
            let fields = '<div class="form-row" id="row'+ i +'">'
                +'<div class="input-group">'
                +'<input type="text" class="form-control" name="lname" placeholder ="Last Name" required>'
                +'<input type="text" class="form-control" name="fname" placeholder ="First Name" required>'
                +'<input type="text" class="form-control" name="mname" placeholder ="Middle Name">'
                +'<select class="form-control" name="gender" required>'
                    +'<option value="">Gender</option><option value="Male">Male</option>'
                    +'<option value="Female">Female</option>'
                +'</select>'
                +'<br>&nbsp;Semester Started:'
                +'<select class="form-control" name="semenrolled1" required>'
                    +'<option>Select Semester</option>'
                    +terms
                +'</select>'
                +'<input type="text" class="form-control" name="acadyear1" placeholder ="Acad Year" required>'
                +'<span class="input-group-addon"><button name="remove" id="'+i+'" class="btn btn-danger btn_remove">'
                +'<span class="glyphicon glyphicon-plus" ></span>'
                +'</button></span>'
                +'</div>'
                +'</div>';

            $('#dynamic_field').append(fields);
        });

        $(document).on('click', '.btn_remove', function(){
            var button_id = $(this).attr("id");
            $("#row"+button_id+"").remove();
        });
    });