webview - كيفية استخدام الكترون<ويبفيو> داخل التطبيق Angular2؟




attributes electron (2)

أحاول استخدام علامة ويكتفيو إليكتون داخل بلدي Angular2 التطبيق، ولكن عندما أضيف سمة سرك بيندد إلى متغير Angular2 يحدث الخطأ التالي:

Can't bind to 'src' since it isn't a known native property

هذا هو index.html:

<head>
    <!-- cut out stylings, metatags, etc. -->
    <script src="../node_modules/zone.js/dist/zone.js"></script>
    <script src="../node_modules/reflect-metadata/Reflect.js"></script>
    <script src="../node_modules/systemjs/dist/system.src.js"></script>
    <script src="systemjs.config.js"></script>
    <script>
        const electron = require('electron');
        System.import('app').catch(function(err){ console.error(err); });
    </script>
</head>
<body>
    <MainComponent>Loading...</MainComponent>
</body>

هذا هو systemjs.config.js:

(function(global) {
// map tells the System loader where to look for things
var map = {
    'app':                        'angular',
    '@angular':                   '../node_modules/@angular',
    'angular2-in-memory-web-api': '../node_modules/angular2-in-memory-web-api',
    'rxjs':                       '../node_modules/rxjs'
};
// packages tells the System loader how to load when no filename and/or no extension
var packages = {
    'app':                        { main: 'main.js',  defaultExtension: 'js' },
    'rxjs':                       { defaultExtension: 'js' },
    'angular2-in-memory-web-api': { defaultExtension: 'js' }
};
var ngPackageNames = [
    'common',
    'compiler',
    'core',
    'http',
    'platform-browser',
    'platform-browser-dynamic',
    'router',
    'router-deprecated',
    'upgrade'
];
// Add package entries for angular packages
ngPackageNames.forEach(function(pkgName) {
    packages['@angular/'+pkgName] = { main: pkgName + '.umd.js', defaultExtension: 'js' };
});
var config = {
    map: map,
    packages: packages
};
System.config(config);
})(this);

هذا هو قالب المكون Angular2 I (أريد) استخدام عرض ويب في:

<div class="stage-component component">
    <webview *ngIf="iFrameUrl" src="{{iFrameUrl}}"></webview>
</div>

كيف يمكنني إدخال عنصر ويبفيو إلى Angular2؟


هذا غريب. يبدو أنك ربما يكون لديك قضية الإصدار. يمكنك محاولة استخدام أبي loadUrl بدلا من ذلك ومعرفة ما إذا كان ذلك يساعد.

<script>
  onload = () => {
    const webview = document.getElementById('foo');
    webview.loadUrl('http://example.com')
</script>

إذا ظهر هذا، استخدم "أتر" من قبل.

<webview *ngIf="iFrameUrl" attr.src="{{iFrameUrl}}"></webview>