ホームページ >ウェブフロントエンド >htmlチュートリアル >フロントエンドを記述するときに yeoman、gulp、angular を使用して HTML テンプレートを処理し、package_html/css_WEB-ITnose の後に HTML が見つからない問題を解決します

フロントエンドを記述するときに yeoman、gulp、angular を使用して HTML テンプレートを処理し、package_html/css_WEB-ITnose の後に HTML が見つからない問題を解決します

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-06-21 09:04:16967ブラウズ

私は最近問題に遭遇しました。つまり、yeoman と gulp を介してフロントエンドを作成するときに、コード内で相対パスが直接書き込まれます。問題は、コードをパッケージ化して公開した後、相対パスを参照する HTML が見つからず、404

というプロンプトが表示されます。gulp を勉強した後、build.js で、一致する HTML ファイルについて記述されたコードが圧縮されていることがわかりました。それらは一致します すべての HTML ファイルは、angularTemplatecatch プラグインを通じて templateCatchHtml.js ファイルに圧縮されます
コードは次のとおりです

gulp.task('partials', function () {  return gulp.src([    path.join(conf.paths.src, '/app/**/*.html'),    path.join(conf.paths.tmp, '/serve/app/**/*.html')  ])    .pipe($.minifyHtml({      empty: true,      spare: true,      quotes: true    }))    .pipe($.angularTemplatecache('templateCacheHtml.js', {      module: 'webapp',      root: 'app'    }))    .pipe(gulp.dest(conf.paths.tmp + '/partials/'));});

つまり、プログラム内でパッケージ化されたテンプレートの ID を直接使用して、対応するhtml

なので、コード内で相対パスを使用しているHTMLを、生成されたテンプレートコードのテンプレートIDに変更します
このようにして、パッケージ化後もdistが正常に使用できるようになります。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。