質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Chrome extension

Chrome拡張機能

Q&A

解決済

1回答

4433閲覧

JavaScript ファイルでjQueryのファイルを読み込むのがうまくいかない(Chrome拡張機能のv2からv3への移行がうまくいかない)

tansann

総合スコア0

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Chrome extension

Chrome拡張機能

0グッド

2クリップ

投稿2021/12/28 02:27

編集2022/01/04 06:05

概要

Manifest versionがv2で作ってちゃんと動いていた自作のChrome拡張機能を、v3仕様にしようとしたところ、うまく動かなくなってしまいました。
その拡張機能は、特定のサイトにボタンを挿入して、それをクリックするとGoogleスプレッドシートにサイトの内容が記録されるというものです。

不具合

特定のサイトにアクセスして挿入されたボタンをクリックしても、スプレッドシートに記録ができなくなっています。ChromeでF12を押して「コンソール」を見たところ、サイトの内容を取得することまではできています。

ページ内の情報を取得、整理する"content.js"はうまくいっているけれど、それをスプレッドシートに送る"background.js"がうまくいっていないように思われます。

やったこと

ファイルはこのようになっています

├─background.js ├─content.js ├─jquery-3.6.0.min.js └─manifest.json

v2からv3に移行するにあたって、それぞれのファイルで変更した箇所を記します。
manifest.json

  • "manifest_version": 2 を3にしました。
  • "background.scripts"の中に"jquery-3.6.0.min.js"と"background.js"という2つのjsファイルがあったので、このサイトを参考に、"background.js"だけにしました。
  • "persistent": false を削除しました。

以下が変更前のmanifest.json のbackcroundです

json

1"background": { 2 "service_worker": [ 3 "jquery-3.6.0.min.js", 4 "background.js" 5 ], 6 "presistent": false 7 }

変更後です。

json

1"background": { 2 "service_worker": 3 "background.js" 4 }

background.js

  • 冒頭1行目でjQueryのファイルを読み込むことにしました。

importScripts("jquery-3.6.0.min.js");

それで上記の不具合がでています。

追記

stack overflowには、importScripts("jquery-3.6.0.min.js");は、$.ajaxを使用していると使えないので代わりにfetch()を使うとよいと書かれていました。
私の拡張機能のbackground.jsにも$.ajax使用されているので、fetch()を使う形で作り変えてみました。
manifest-versionが2のときはちゃんと動きましたが、3になると動かなくなってしまいました。

追記 エラー

ビューを検証 Service Worker では、このようなエラーが出ています。

jquery-3.6.0.min.js:2 Uncaught TypeError: Cannot read properties of undefined (reading 'createElement') at ce (jquery-3.6.0.min.js:2) at jquery-3.6.0.min.js:2 at jquery-3.6.0.min.js:2 at jquery-3.6.0.min.js:2 at jquery-3.6.0.min.js:2 at background.js:2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決しました。

まずbackground.jsで$ajaxを使っていたのをfetch()にして、jQueryの読み込みを必要なくしました。

しかし、CORSで引っかかってしまいました。

そこで、manifest.jsonで、

"host_permissions": [ "https://script.google.com/*" ]

というのを追加しました。

投稿2022/01/04 07:44

編集2022/01/04 07:45
tansann

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問