ホームページ >ウェブフロントエンド >フロントエンドQ&A >vue が id 属性を取得できない場合はどうすればよいですか?
getElementById が「created()」フック関数で使用されており、Vue のマウントがまだ完了していないため、Vue は id 属性を取得できません。解決策は、「created() {let serachBox = document.getElementById」を変更することです。 ('searchBox');...}" コードを "mounted()" フック関数に移行できます。
このチュートリアルの動作環境: Windows 10 システム、vue3 バージョン、DELL G3 コンピューター
vue の場合はどうすればよいですかid属性を取得できないのですか?
#Vue で getElementById を使用した結果、返される要素は null です?
element.getBoundingClientRect を通じて固定要素のサイズを取得し、次に ## を通じて固定要素のサイズを取得することです。 #document.body.offsetHeight
ビュー領域の高さ、そして最終的にメイン領域のサイズが動的に計算されます。
エラーの説明に従って、
searchBox 要素を上向きに出力しました。この時点では、 、コンソールには結果が
として出力されました。これは少し興味深いです。 mounted() での getElementById の使用
を通じて Dom 要素を取得できないため、コンソールには null
が出力されます。理由を見つけた後、上記のコードを mounted()
フック関数に移行すると、コンソールに正しい結果が表示されました。 問題は見つかりましたが、ページのレンダリング結果はニーズを満たしていませんでした。私たちは方法を見つけ続けなければなりません。
ビジネス要件を達成するために、Created() が this.$nextTick() と結合されます
//此处省去无关代码 created() { let serachBox = document.getElementById('searchBox'); let searchRect = serachBox .getBoundingClientRect(); console.log('rect',searchRect ); let dffsetHeight = document.body.offsetHeight; this.tHeight = ( dffsetHeight - searchRect .bottom - 100 );},
概要
vue ビデオ チュートリアル
」以上がvue が id 属性を取得できない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。