gpt4 book ai didi

javascript - Laravel - 让 vue 与其他插件一起工作

转载 作者:搜寻专家 更新时间:2023-10-30 22:13:36 25 4
gpt4 key购买 nike

我有一个项目想使用这个 theme .我刚刚下载了它并将其脚本放入 resources/assets/js 目录中。这就是我在运行 gulp 之后调用页面所需的所有脚本的方式:

<!-- Scripts -->
<script
type="text/javascript" src="https://code.jquery.com/jquery-3.1.1.min.js"
integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8="
crossorigin="anonymous"></script>
<script src="/js/bootstrap.min.js" type="text/javascript"></script>
<script type="text/javascript" src="/js/material/material.min.js"></script>
<script type="text/javascript" src="/js/material/ripples.min.js"></script>
<script>$.material.init()</script>

<!-- Checkbox, Radio & Switch Plugins -->
<script src="/js/bootstrap-checkbox-radio.js"></script>

<!-- Notifications Plugin -->
<script src="/js/bootstrap-notify.js"></script>

<!-- Paper Dashboard Core javascript and methods for Demo purpose -->
<script src="/js/paper-dashboard.js"></script>



<script type="text/javascript">
$(document).ready(function(){
$.notify({
icon: 'ti-gift',
message: "Welcome to <b>Paper Dashboard</b> - a beautiful Bootstrap freebie for your next project."

},{
type: 'success',
timer: 4000
});

});
</script>
<script src="/js/app.js"></script>

但是我无法让 Bootstrap 通知或工具提示工作,如果我删除 app.js 我让它再次工作,但是 vue 组件无法工作。

这是 app.js:

/**
* First we will load all of this project's JavaScript dependencies which
* include Vue and Vue Resource. This gives a great starting point for
* building robust, powerful web applications using Vue and Laravel.
*/

require('./bootstrap');

var VueResource = require('vue-resource');

/**
* Next, we will create a fresh Vue application instance and attach it to
* the body of the page. From here, you may begin adding components to
* the application, or feel free to tweak this setup for your needs.
*/

Vue.component('video-upload', require('./components/VideoUpload.vue'));
Vue.component('video-player', require('./components/VideoPlayer.vue'));
Vue.component('video-voting', require('./components/VideoVoting.vue'));

Vue.use(VueResource);

const app = new Vue({
el: 'body',
data: window.videoApp
});

这是 gulpfile:

const elixir = require('laravel-elixir');

require('laravel-elixir-vue');

/*
|--------------------------------------------------------------------------
| Elixir Asset Management
|--------------------------------------------------------------------------
|
| Elixir provides a clean, fluent API for defining some basic Gulp tasks
| for your Laravel application. By default, we are compiling the Sass
| file for our application, as well as publishing vendor resources.
|
*/

elixir(mix => {
mix.copy('resources/assets/js', 'public/js');
mix.copy('resources/assets/css', 'public/css');

mix.sass('app.scss')
.webpack('app.js');
});

更新

我在我的 bootstrap.js 文件底部按照 craig_h 的建议要求,如下所示:

require('./bootstrap-checkbox-radio.js');
require('./bootstrap-notify.js');
require('./paper-dashboard.js');

但是我得到一个错误:

paper-dashboard.js?16eb:26Uncaught ReferenceError: lbd is not defined(…)

这是脚本 paper-dashboard.js:

var fixedTop = false;

var navbar_initialized = false;

$(document).ready(function(){
window_width = $(window).width();

// Init navigation toggle for small screens
if(window_width <= 991){
lbd.initRightMenu();
}

// Activate the tooltips
$('[rel="tooltip"]').tooltip();

});

// activate collapse right menu when the windows is resized
$(window).resize(function(){
if($(window).width() <= 991){
lbd.initRightMenu();
}
});

lbd = {
misc:{
navbar_menu_visible: 0
},

initRightMenu: function(){
if(!navbar_initialized){
$off_canvas_sidebar = $('nav').find('.navbar-collapse').first().clone(true);

$sidebar = $('.sidebar');
sidebar_bg_color = $sidebar.data('background-color');
sidebar_active_color = $sidebar.data('active-color');

$logo = $sidebar.find('.logo').first();
logo_content = $logo[0].outerHTML;

ul_content = '';

// set the bg color and active color from the default sidebar to the off canvas sidebar;
$off_canvas_sidebar.attr('data-background-color',sidebar_bg_color);
$off_canvas_sidebar.attr('data-active-color',sidebar_active_color);

$off_canvas_sidebar.addClass('off-canvas-sidebar');

//add the content from the regular header to the right menu
$off_canvas_sidebar.children('ul').each(function(){
content_buff = $(this).html();
ul_content = ul_content + content_buff;
});

// add the content from the sidebar to the right menu
content_buff = $sidebar.find('.nav').html();
ul_content = ul_content + '<li class="divider"></li>'+ content_buff;

ul_content = '<ul class="nav navbar-nav">' + ul_content + '</ul>';

navbar_content = logo_content + ul_content;
navbar_content = '<div class="sidebar-wrapper">' + navbar_content + '</div>';

$off_canvas_sidebar.html(navbar_content);

$('body').append($off_canvas_sidebar);

$toggle = $('.navbar-toggle');

$off_canvas_sidebar.find('a').removeClass('btn btn-round btn-default');
$off_canvas_sidebar.find('button').removeClass('btn-round btn-fill btn-info btn-primary btn-success btn-danger btn-warning btn-neutral');
$off_canvas_sidebar.find('button').addClass('btn-simple btn-block');

$toggle.click(function (){
if(lbd.misc.navbar_menu_visible == 1) {
$('html').removeClass('nav-open');
lbd.misc.navbar_menu_visible = 0;
$('#bodyClick').remove();
setTimeout(function(){
$toggle.removeClass('toggled');
}, 400);

} else {
setTimeout(function(){
$toggle.addClass('toggled');
}, 430);

div = '<div id="bodyClick"></div>';
$(div).appendTo("body").click(function() {
$('html').removeClass('nav-open');
lbd.misc.navbar_menu_visible = 0;
$('#bodyClick').remove();
setTimeout(function(){
$toggle.removeClass('toggled');
}, 400);
});

$('html').addClass('nav-open');
lbd.misc.navbar_menu_visible = 1;

}
});
navbar_initialized = true;
}

}
}


// Returns a function, that, as long as it continues to be invoked, will not
// be triggered. The function will be called after it stops being called for
// N milliseconds. If `immediate` is passed, trigger the function on the
// leading edge, instead of the trailing.

function debounce(func, wait, immediate) {
var timeout;
return function() {
var context = this, args = arguments;
clearTimeout(timeout);
timeout = setTimeout(function() {
timeout = null;
if (!immediate) func.apply(context, args);
}, wait);
if (immediate && !timeout) func.apply(context, args);
};
};

如果这是初学者的问题,我深表歉意,但我之前没有使用过 webpack 或 browserify,所以我不知道如何设置所有这些。

最佳答案

我不使用 webpack 我使用 browserify 代替,但我认为问题是你正在使用依赖于全局变量的包,如果你想这样做那么您需要使用进口商,请参阅 shimming modules

但是,您通常可以像这样在 /resources/assets/js/bootstrap.js 中要求它们:

require('./bootstrap-checkbox-radio.js')

require('./bootstrap-notify.js')

require('./paper-dashboard.js')

然后运行 ​​gulp

关于javascript - Laravel - 让 vue 与其他插件一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40486714/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com