Laravel冲突脚本,引导程序

时间:2020-07-02 04:24:22

标签: php laravel bootstrap-4 datatables mdbootstrap

在我当前的Laravel项目中,我同时使用(尝试)了Bootstrap和MDBoostrap。当前,我遇到错误TypeError: $(...).DataTable is not a function,并且从在线阅读此书时,通常是由于多次调用jquery所致。我相信该错误与app.js有关,但是如果我仅包含Bootstraps所需的数据表脚本,则会收到$不确定的错误。注意: index.blade.html app.blade.html 的扩展。使用Laravel,我仅尝试使用MDB创建数据表。这可能与here重复,但是此问题从未得到解答。我整整一天都在努力解决这个问题,任何投入都是值得的。

app.blade.html

<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="{{asset('css/app.css')}}">

    <title>Laravel Project</title>

</head>
<body>
<div class="container">
    @yield('content')
</div>
<script src="{{asset('js/app.js')}}"></script>
<script>
    // Material Design example
    $(document).ready(function () {
        $('#dtMaterialDesignExample').DataTable();
        $('#dtMaterialDesignExample_wrapper').find('label').each(function () {
            $(this).parent().append($(this).children());
        });
        $('#dtMaterialDesignExample_wrapper .dataTables_filter').find('input').each(function () {
            const $this = $(this);
            $this.attr("placeholder", "Search");
            $this.removeClass('form-control-sm');
        });
        $('#dtMaterialDesignExample_wrapper .dataTables_length').addClass('d-flex flex-row');
        $('#dtMaterialDesignExample_wrapper .dataTables_filter').addClass('md-form');
        $('#dtMaterialDesignExample_wrapper select').removeClass('custom-select custom-select-sm form-control form-control-sm');
        $('#dtMaterialDesignExample_wrapper select').addClass('mdb-select');
        $('#dtMaterialDesignExample_wrapper .mdb-select').materialSelect();
        $('#dtMaterialDesignExample_wrapper .dataTables_filter').find('label').remove();
    });
</script>

</body>
</html>

index.blade.html

@extends('layouts.app')

@section('content')
    <h1>User Table</h1>

    @if(count($users) > 0)
        <table id="dtMaterialDesignExample" class="table" cellspacing="0" width="100%">
            <thead>
            <tr>
                <th class="th-sm">ID
                </th>
                <th class="th-sm">Name
                </th>
                <th class="th-sm">Occupation
                </th>
                <th class="th-sm">Location
                </th>
                <th class="th-sm">Salary
                </th>
            </tr>
            </thead>
            <tbody>
            @foreach($users as $user)
                <tr>
                    <td>{{$user->id}}</td>
                    <td>{{$user->name}}</td>
                    <td>{{$user->occupation}}</td>
                    <td>{{$user->location}}</td>
                    <td>{{$user->salary}}</td>
                </tr>
            @endforeach
            </tbody>
        </table>
    @endif
@endsection

UsersController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\User;

class UsersController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $users = User::orderBy('id', 'asc')->paginate(10);
        return view('users.index',['users'=>$users]);
    }

bootstrap.js

try {
    window.Popper = require('popper.js').default;
    window.$ = window.jQuery = require('jquery');

    require('bootstrap');
    require('mdbootstrap');
} catch (e) {}

app.js

require('./bootstrap');
var moment = require('mdbootstrap');

app.scss

// Fonts
@import url('https://fonts.googleapis.com/css?family=Nunito');

// Variables
@import 'variables';

// Bootstrap
@import '~bootstrap/scss/bootstrap';

// MDBootstrap
@import '~mdbootstrap/css/mdb.min.css';

1 个答案:

答案 0 :(得分:2)

如果这是DataTables.net软件包,我相信您必须包括JS以及CSS才能成功$('#dtMaterialDesignExample').DataTable();。我知道,Bootstrap并不具备这些功能。我有一个使用Vanilla Bootstrap的Laravel软件包,我必须包括JS和CSS来呈现数据表。

我对MDB并不十分熟悉。他们可能提供CSS,但我不知道他们是否提供JS。似乎没有一个重复的定义,因此您需要确保您的应用正在向浏览器呈现如下内容:

<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.21/css/jquery.dataTables.min.css"/>
<script src="https://cdn.datatables.net/1.10.21/js/jquery.dataTables.min.js" type="text/javascript"></script>

这将包括DataTable()函数的JS定义。

相关问题