Javascript - 找不到导入

标签 javascript laravel laravel-5 node-modules

我正在尝试使文本屏蔽 GitHub 存储库与我的 laravel 项目一起工作,有了这个,我想使用某个插件,它允许我将输入字段屏蔽为价格。我说的 GitHub 存储库是 linked here

该插件名为 createNumberMask,在他们的 github 页面上,他们的文档中说明如下:

import createNumberMask from 'text-mask-addons/dist/createNumberMask'

// First, you need to create the `numberMask` with your desired configurations
const numberMask = createNumberMask({
   prefix: '',
   suffix: ' $' // This will put the dollar sign at the end, with a space.
})

// ...then pass `numberMask` to the Text Mask component as the mask

现在,当我尝试将它实现到我自己的项目中时,它给我一个错误,指出找不到导入。这是什么原因造成的?

我有一个 blade 文件,它的底部有脚本标签。 Blade 文件看起来像这样,

@section('content')
<div class="row " style="color: white; width: 100%; margin: 0;" id="showEffect">
    <div class="col-md-12 text-center" style="margin-top: 10rem">
        <div class="row justify-content-md-center">
            <div class="col-md-2">
                <input type="text" class="myInput form-control depth-5">
            </div>
        </div>

    </div>
</div>


<script type="module">

    import createNumberMask from '/node_modules/text-mask-addons/dist/createNumberMask'

    const numberMask = createNumberMask({
        prefix: '€',
        suffix: '',
        allowDecimal: true,
    });

    var myInput = document.querySelector('myInput');

    var maskedInputController = vanillaTextMask.maskInput({
        inputElement: document.querySelector('myInput'),
        mask: numberMask
    });


</script>

@endsection

为什么导入不起作用? js 文件位于 node_modules 文件夹中。

APP.JS

require('./bootstrap');

import TextMask from 'vanilla-text-mask/dist/vanillaTextMask';
import createNumberMask from 'text-mask-addons/dist/createNumberMask';

window.Vue = require('vue');

window.events = new Vue();

window.flash = function (message) {
    window.events.$emit('flash', message);
};


Vue.component('flash', require('./components/Flash.vue'));

// Vue.component('product-view', require('./components/Products.vue'));
// Vue.component('wysiwyg', require('./components/Wysiwyg.vue'));

const app = new Vue({
el: '#app',
});

const numberMask = createNumberMask({
prefix: '€',
suffix: '',
allowDecimal: true,
});

var myInput = document.querySelector('myInput');

var maskedInputController = vanillaTextMask.maskInput({
    inputElement: document.querySelector('myInput'),
    mask: numberMask
});

最佳答案

代码包含在 Blade 模板中,而不是通过 resources/assets/js/app.js 或任何类型的 javascript 编译器(在本例中为“webpack”)

问题是虽然大多数浏览器都理解 ~ ES6,但导入/要求仍然存在限制。

由于 node_modules 在服务器端,前端不能直接访问它。

所以您可以/需要做的是以一种或另一种方式将其添加到提到的 javascript 文件中,然后使用 npm run dev 或类似的方式对其进行编译。

关于Javascript - 找不到导入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50169526/

相关文章:

javascript - Jquery Ui 日期时间选择器

laravel - 测试 Laravel Eloquent 关系

json - 如何在laravel中为api返回json格式而不是html

MySQL/Laravel/Vue - 单个表单输入可以将多个值提交到多个列吗?

php - 模型中的 Laravel 5 验证

php - 类 App\Http\Controllers\PostController 不存在

mysql - 为什么 Laravel 中没有插入数据?

javascript - 什么是 Extjs 中的视口(viewport)

javascript - bootstrap Accordion 或隐藏和显示在 jQuery 中动态创建的元素下不起作用

php - 日常风采网站