如何使用 jQuery 和使用 Laravel 变量检查复选框

发布于 2025-01-15 21:01:48 字数 4023 浏览 1 评论 0原文

我想知道如何检查与我的 jQuery 搜索功能找到的学生关联的复选框。要理解这里的是我的“Ajax”请求。目前,它在 html“span”中显示我的搜索结果,但我只想选中与搜索关联的复选框。

这是我执行请求的 jQuery 代码:

const { post } = require("jquery");

const form = document.getElementById('search-codebar-form');

form.addEventListener('submit', function (e) {
    e.preventDefault();

    const token = document.querySelector('meta[name="csrf-token"]').content;
    const url = this.getAttribute('action');
    const q = document.getElementById('q').value;
   

    fetch(url, {
        headers: {
            'Content-Type': 'application/json',
            'X-CSRF-TOKEN': token
        },
        method: 'post',
        body: JSON.stringify({
          q: q
        })
    }).then(response =>  {
        response.json().then (data => {

            // const newid = "student-${{id}}";

             document.getElementById(newid).checked = true;
            var data = {};
            data = "{{ $student->id }}";
    $("#student-.data").prop("checked", true); // And here I'm trying to take the id of the checkbox
 and check it.Watch out because the id change with the result because it is "student-{{ $student->id }}"
----------------------------------------------------------------
           // const etudiant = document.getElementById('etudiant');
            etudiant.innerHTML = '';


            Object.entries(data)[0][1].forEach(element =>{
               etudiant.innerHTML = `<span>${element.first_name}</span>`// At the moment
 I have this .So this empty my "div" and show the name of the result.
              
            });
        })
    }).catch(error =>{
        console.log(error)
    })

});

这是我的表单,此输入位于我的 .blade 中 标签 '' 在我的代码中要高得多,但我只想向您展示最重要的内容。

<div id="etudiant">         
                  @foreach ($students as $student)
                   <tbody class="bg-white divide-y divide-gray-200">
                      <tr>
                        <td class="px-6 py-4 whitespace-nowrap">                
                              <div class="text-sm font-medium text-gray-900">
                      {{$student->last_name}}
                          </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">
                          {{$student->first_name}}
                            </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">
                          {{$student->uuid}}
                            </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">      
                             <input class="form-check-input" type="checkbox"  name="students[]" type="checkbox" value="{{ $student->id }}" id="student-{{ $student->id }}" />    
                            </div>
                        </td>
                      </tr>
                    </tbody> 
                   
                    @endforeach 
                       </div>

如果您想要更多,这是与请求关联的 Laravel 控制器。

public function search_codebar(request $request): JsonResponse
    {

      $q = $request->input('q');

      $students = Student::where('uuid', 'like' ,$q )->get();

      return response()->json([
        "students" => $students]);
    }
    public function list_appel($id){
    return view('list_appel', ["appels" => Appel::all()]);
    
    }

所以我的 jQuery 代码中的“q”在这里定义来搜索学生的“uuid”。 我希望你能理解我的问题是什么。 多谢 !

https://i.sstatic.net/1eqcK.png

I would like to know how to check the checkbox that is associated with the student found by my jQuery search function.To understand here is my "Ajax" request. Currently it displays the result of my search in a html 'span' but I just want to check the checkbox associated with the search.

This is my jQuery code where I do my request :

const { post } = require("jquery");

const form = document.getElementById('search-codebar-form');

form.addEventListener('submit', function (e) {
    e.preventDefault();

    const token = document.querySelector('meta[name="csrf-token"]').content;
    const url = this.getAttribute('action');
    const q = document.getElementById('q').value;
   

    fetch(url, {
        headers: {
            'Content-Type': 'application/json',
            'X-CSRF-TOKEN': token
        },
        method: 'post',
        body: JSON.stringify({
          q: q
        })
    }).then(response =>  {
        response.json().then (data => {

            // const newid = "student-${{id}}";

             document.getElementById(newid).checked = true;
            var data = {};
            data = "{{ $student->id }}";
    $("#student-.data").prop("checked", true); // And here I'm trying to take the id of the checkbox
 and check it.Watch out because the id change with the result because it is "student-{{ $student->id }}"
----------------------------------------------------------------
           // const etudiant = document.getElementById('etudiant');
            etudiant.innerHTML = '';


            Object.entries(data)[0][1].forEach(element =>{
               etudiant.innerHTML = `<span>${element.first_name}</span>`// At the moment
 I have this .So this empty my "div" and show the name of the result.
              
            });
        })
    }).catch(error =>{
        console.log(error)
    })

});

And this is my form where this input is in my .blade
The tag '' is much higher in my code but I just wanna show you the most important.

<div id="etudiant">         
                  @foreach ($students as $student)
                   <tbody class="bg-white divide-y divide-gray-200">
                      <tr>
                        <td class="px-6 py-4 whitespace-nowrap">                
                              <div class="text-sm font-medium text-gray-900">
                      {{$student->last_name}}
                          </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">
                          {{$student->first_name}}
                            </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">
                          {{$student->uuid}}
                            </div>
                        </td>
                        <td class="px-6 py-4 whitespace-nowrap">
                            <div class="text-sm font-medium text-gray-900">      
                             <input class="form-check-input" type="checkbox"  name="students[]" type="checkbox" value="{{ $student->id }}" id="student-{{ $student->id }}" />    
                            </div>
                        </td>
                      </tr>
                    </tbody> 
                   
                    @endforeach 
                       </div>

If you want more this is my Laravel controller associate to the request.

public function search_codebar(request $request): JsonResponse
    {

      $q = $request->input('q');

      $students = Student::where('uuid', 'like' ,$q )->get();

      return response()->json([
        "students" => $students]);
    }
    public function list_appel($id){
    return view('list_appel', ["appels" => Appel::all()]);
    
    }

So "q" in my jQuery code in define here to search the "uuid" of the student.
I hope you can understand what is my problem.
Thanks a lot !

https://i.sstatic.net/1eqcK.png

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

衣神在巴黎 2025-01-22 21:01:48

data = "{{ $student->id }}";

似乎不属于那里。它不是 JavaScript 的一部分,将在页面加载时填充。这不太可能是您想要的

如果您的服务器返回包含学生数组并具有 uuid 的 JSON,那么您可以执行类似的操作

 }).then(response => response.json())
  .then (data => {
    data.forEach(student => $(`#student-${student.id}`).prop("checked", true))

data = "{{ $student->id }}";

does not seem to belong there. It is not part of the JavaScript and will be filled in when the page loads. That is unlikely what you want

IF your server returns JSON that contains an array of students and has the uuid, then you can do something like

 }).then(response => response.json())
  .then (data => {
    data.forEach(student => $(`#student-${student.id}`).prop("checked", true))
远昼 2025-01-22 21:01:48

我找到了答案:

.then((response) => response.json())
        .then((data)=>{
const students = data.students
students.forEach((student) => {
                $(`#student-${student.id}`).prop("checked", true)
            
            })

        })  
        .catch((error) => {
            console.log(error);
        });
    });

我的数据是一个对象而不是数组!
所以我不得不使用 .then((data)=>{ const Students = data.students

I found the answer :

.then((response) => response.json())
        .then((data)=>{
const students = data.students
students.forEach((student) => {
                $(`#student-${student.id}`).prop("checked", true)
            
            })

        })  
        .catch((error) => {
            console.log(error);
        });
    });

My data was an object and not an array !
So I had to use .then((data)=>{ const students = data.students

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文