我在larvel 5.8中将vuejs与刀片文件一起使用。意味着我没有使用vue路由器,而是laravel视图。 最近我面临一个大问题,我的public / js / app.js文件大小约为13 MB! 当我部署到生活中时,用户登录时会变慢! 我什至无法分析,因为我看不到任何名为webpack.config shown here
的配置文件我的app.js:
import Vue from "vue";
window.Vue = Vue;
window.axios = require("axios");
window.axios.defaults.headers.common["X-Requested-With"] = "XMLHttpRequest";
require("promise.prototype.finally").shim();
import { Form, HasError, AlertError } from "vform";
window.Form = Form;
Vue.component(HasError.name, HasError);
Vue.component(AlertError.name, AlertError);
Vue.component("pagination", require("laravel-vue-pagination"));
//sweet alert 2
import swal from "sweetalert2";
window.swal = swal;
const toast = swal.mixin({
toast: true,
position: "top-end",
showConfirmButton: false,
timer: 15000
});
window.toast = toast;
//vue lang
import VueInternationalization from "vue-i18n";
import Locale from "./vue-i18n-locales.generated";
Vue.use(VueInternationalization);
const lang = document.documentElement.lang.substr(0, 2);
// or however you determine your current app locale
const i18n = new VueInternationalization({
locale: lang,
messages: Locale
});
//vue lang end
//https://hamed-ehtesham.github.io/pretty-checkbox-vue/#installation
import PrettyCheckbox from "pretty-checkbox-vue";
Vue.use(PrettyCheckbox);
//vue autocomplete
//ckeditor
import CKEditor from "@ckeditor/ckeditor5-vue";
Vue.use(CKEditor);
/**
* Next, we will create a fresh Vue ap
*
*
* plication instance and attach it to
* the page. Then, you may begin adding components to this application
* or customize the JavaScript scaffolding to fit your unique needs.
*/
// dash board
Vue.component(
"dashboard-site-employee-attendance-list",
require("./components/dashboard/site/employeeAttendanceListComponent.vue")
);
Vue.component(
"employee-attendance-master-component",
require("./components/dashboard/site/latestAttendanceListComponent.vue")
);
Vue.filter("round", function(value) {
return parseFloat(value).toFixed(0);
});
const app = new Vue({
el: "#app",
i18n,
components: {},
methods: {},
mounted() {
console.log("d" + document.documentElement.lang.substr(0, 2));
}
});
N> B:我所有的成分都注入了这里(为精确起见仅提及2)
刀片文件:
@extends('default.admin.layouts.master')
@section('style')
{!! Html::style('css/styles.css') !!}
@endsection
@section('content')
<div class="container-fluid min_height_area">
<div class="row">
<div class="col-md-12">
<div class="view-header">
<section class="content-header">
<ol class="breadcrumb">
<li>
<span class="fa fa-dashboard" aria-hidden="true"></span>
<a href="{{route('admin')}}">{{ trans('translate.dashboard') }}</a></li>
<li class="active text-capitalize">{{ request()->route()->getName() }}</li>
</ol>
</section>
</div>
</div>
</div>
<employee-attendance-master-component
>
</employee-attendance-master-component>
</div>
@endsection
@section('hscripts')
<script>
window.routes = {
'attendance_list_by_shift_date': '{{ route('all-employee-attendance-list-by-shift-date') }}',
'route_attendance_get_shift_list': '{{ route('site-employee-get-shift-list-for-employee') }}',
'route_employee_attendance_edit': '{{ route('employee-attendance-edit') }}',
'route_take_access_time': '{{ route('employee-attendance-take-access-time') }}',
'route_log_by_date_and_username': '{{ route('edu-device-log-get-device-log-by-date-and-username') }}',
'route_send_sms': '{{ route('site-employee-attendance-send-sms') }}',
'route_report_date_shift': '{{ route('site-employee-attendance-report-date-and-shift') }}',
'route_open_pdf_file': '{{ route('open-pdf-file-storage',['']) }}',
'route_report_month_shift': '{{ route('site-employee-attendance-report-month-and-shift') }}',
'route_emp_list': '{{ route('site-employee-get-simple-active-list') }}',
'route_emp_yearly_report': '{{ route('site-employee-attendance-employee-wise-yearly-report') }}',
'route_site_year_list': '{{ route('get-all-type-academic-year-list') }}',
'route_user_list': '{{ route('site-user-get-site-user-by-user-type') }}',
'route_user_data_update': '{{ route('site-user-data-update',['']) }}',
}
</script>
@endsection
Webpack.mix.js
mix.js('resources/js/app.js', 'public/js')
.sass('resources/sass/app.scss', 'public/css');
我的package.json文件
EDit
答案 0 :(得分:3)
npm run prod
mix.js('resources/js/app.js', 'public/js')
.sass('resources/sass/app.scss', 'public/css')
.extract();
您还可以指示Webpack
编译特定于页面的javascript和vue组件,以便可以将它们分别包含在刀片视图中,请参见this answer
答案 1 :(得分:0)
请考虑有关 Vue.js应用性能优化的系列文章,这些对理解延迟加载,缩小大小和减少应用加载时间确实有很大帮助。 / p>
主要内容: