スキップしてメイン コンテンツに移動

Google Bardがサブルーチンにまとめてくれた例

 $(function() {

// onload時にSelect要素の値を取得して、 // `other-element`要素の表示状態を変更する var selectValue = $("#project_custom_field_values_2").val(); if (selectValue == "従事していない") { $('p').each(function () { var p = $(this); var labels = $(this).find('label'); var label = labels.first(); var innerText = label.text(); //console.log(innerText); switch (innerText) { case "test": p.hide(); var inputs = p.find('input'); inputs.hide(); break; case "test2": p.hide(); break; case "症状": p.hide(); break; default: console.log(""); } }); } else { $('p').each(function () { var p = $(this); var labels = $(this).find('label'); var label = labels.first(); var innerText = label.text(); //console.log(innerText); switch (innerText) { case "test": p.show(); break; case "test2": p.show(); break; case "症状": p.show(); break; default: console.log(""); } }); } $("#project_custom_field_values_2").on("change", function() { if ($(this).val() == "従事していない") { $('p').each(function () { var p = $(this); var labels = $(this).find('label'); var label = labels.first(); var innerText = label.text(); //console.log(innerText); switch (innerText) { case "test": p.hide(); var inputs = p.find('input'); inputs.hide(); break; case "test2": p.hide(); break; case "症状": p.hide(); break; default: console.log(""); } }); } else { $('p').each(function () { var p = $(this); var labels = $(this).find('label'); var label = labels.first(); var innerText = label.text(); //console.log(innerText); switch (innerText) { case "test": p.show(); break; case "test2": p.show(); break; case "症状": p.show(); break; default: console.log(""); } }); } }); }); 上記のコードに重複しているif とelse の間のコードをサブルーチンにできますか?書き直してください。


【Google Bardの回答】


はい、重複しているifとelseの間のコードをサブルーチンにすることができます。

書き直したコードは、次のようになります。

JavaScript
$(function() {

  // onload時にSelect要素の値を取得して、
  // `other-element`要素の表示状態を変更する
  var selectValue = $("#project_custom_field_values_2").val();
  if (selectValue == "従事していない") {

    // サブルーチンを呼び出す
    hideElements();

  } else {

    // サブルーチンを呼び出す
    showElements();

  }

  // onChangeイベントをハンドリングする
  $("#project_custom_field_values_2").on("change", function() {
    if ($(this).val() == "従事していない") {

      // サブルーチンを呼び出す
      hideElements();

    } else {

      // サブルーチンを呼び出す
      showElements();

    }
  });
});

// サブルーチン
function hideElements() {
  // p要素をすべて取得する
  var ps = $("p");

  // p要素ごとに処理を行う
  ps.each(function() {
    // ラベル要素を取得する
    var label = $(this).find("label").first();

    // ラベルのテキストを取得する
    var innerText = label.text();

    // switch文で処理を行う
    switch (innerText) {
      case "test":
        // p要素を非表示にする
        $(this).hide();
        break;
      case "test2":
        // p要素を非表示にする
        $(this).hide();
        break;
      case "症状":
        // p要素を非表示にする
        $(this).hide();
        break;
      default:
        // 何もしない
        break;
    }
  });
}

function showElements() {
  // p要素をすべて取得する
  var ps = $("p");

  // p要素ごとに処理を行う
  ps.each(function() {
    // ラベル要素を取得する
    var label = $(this).find("label").first();

    // ラベルのテキストを取得する
    var innerText = label.text();

    // switch文で処理を行う
    switch (innerText) {
      case "test":
        // p要素を表示する
        $(this).show();
        break;
      case "test2":
        // p要素を表示する
        $(this).show();
        break;
      case "症状":
        // p要素を表示する
        $(this).show();
        break;
      default:
        // 何もしない
        break;
    }
  });
}

この書き直したコードでは、重複しているifとelseの間のコードを、hideElements()とshowElements()という2つのサブルーチンに分離しました。

hideElements()サブルーチンは、p要素を非表示にする処理を行います。showElements()サブルーチンは、p要素を表示する処理を行います。

onLoadイベントとonChangeイベントのハンドリングも、サブルーチンを呼び出すように変更しました。

この書き直したコードにより、コードの可読性と保守性が向上します。また、コードの重複を排除することで、パフォーマンスの向上も期待できます。


コメント

このブログの人気の投稿

iPhoneのカレンダーに見知らぬアカウントによるフィティングリンクの恐れ

 昨日突然妻から、iPhoneのカレンダーに怪しい予定はいっぱい書き込まれました。 最初はメールアドレスの盗用されたと思って、メールアカウントのパスワードと、そのメールアドレスのApple IDのパスワードを急遽変更しました。しかし、書き込みが消えず、よくカレンダーの設定のアカウントを調べると下記の画像のような気持ち悪いアカウントがいつの間にか設定されてしまいました。おそらく料理紹介のホームページにある怪しい広告をクリックしたかもしれません。くれぐれもご注意ください。 幸い、このアカウントを削除すれば、書き込みも消えました。なにが違和感を感じたときは、絶対にリンク等をクリックしないほうが身のためでしょう。 さらにnslookupで ylevelsoft.funを調べてみるとIPは13.226.77.* セグメント内の4つのようです。 $ nslookup ylevelsoft.fun Server:         192.168.11.1 Address:        192.168.11.1#53 Non-authoritative answer: Name:   ylevelsoft.fun Address: 13.226.77.19 Name:   ylevelsoft.fun Address: 13.226.77.33 Name:   ylevelsoft.fun Address: 13.226.77.8 Name:   ylevelsoft.fun Address: 13.226.77.15 これらのIPアドレスを調べると、東京にあるIPアドレスがわかって、Amazonにホスティングしてるようです。 13.226.77.19 IP Address Details - IPinfo.io カレンダーのアカウントに登録したサーばをnslookupを調べると13.33.9.*セグメントの4つが使われて、Amazonにホスティングしてるようです。 このホスト名は、server-13-33-9-105.nrt57.r.cloudfront.net 上記のIPのホスト名server-13-...

Excel Power Query 英数字の全角から半角への変換

最近仕事上でExcelのPower Queryを始めました。しかし、英数字の全角から半角への変換関数がないため、下記のサイトを参考して、 作っちゃいました。  https://qiita.com/baku2san/items/8041d0259fe0db680e7e https://www.yoheim.net/blog.php?q=20191101 (original as text) as text =&gt; let    originalText = Text.Combine({original, ""}),    replaceResult =  Web.Page("<script>var originalText="&"'"&originalText&"'"&";var result=originalText.replace(/[A-Za-z0-9]/g, function(s) {return String.fromCharCode(s.charCodeAt(0) - 0xFEE0);});document.write(result);</script>")       [Data]{0}[Children]{0}[Children],    result = if (List.Count(replaceResult) &lt;= 1) then    {        "" as text // 変換して何も残らない場合    } else if (replaceResult{1}[Text]{0} = null) then    {       originalText   as text// 何も見つからない場合    }  else {       replaceResult{1}[Text]{0} as text    } in ...

閉域網の電子カルテにJitsiを稼働させてみた!(続き)

 前回は、 閉域網の電子カルテにJitsiを稼働してみた! を紹介しました。 サーバは古いMacminiですが、今回はインターネット環境のWindows 10のHyper-VでDebian 10を入れて、仮想サーバを電子カルテネットワーク内の、Windows server 2019とWindows server 2008のHyper-Vに移植する試みを紹介します。 Hyper-Vにすることで、新しい研究用仮想基盤や古いサーバ(旧国立大バックアップシステム等)の仮想基盤化で必要数に応じて簡単にJitsiサーバを増やすことが可能という利点があります。それから、故障した場合も簡単に他のHyper-V仮想基盤にすぐ再稼働することが可能なので耐障害になります。 今回利用したDebianのインストーラは、 debian-10.7.0-amd64-netinst.iso です。 基本のDebianのインストールはインストーラの指示通りでできますので、こちらで割愛します。必要なサービスは、VNCやSSHあたりです。GUIが利用したい場合、お好みのデスクトップで構いません。 Jitsi Meetのインストールは、 こちらのサイト(英文) を参考していますが、 こちらの環境では、下記のコマンドでやってみました。ドメイン名を使わず、IPアドレスのみでの設定なので、Hyper-Vのチェックポインの機能でIP変更のたびにJitsiをインストールします。 $ wget https://download.jitsi.org/jitsi-key.gpg.key $ sudo apt-key add jitsi-key.gpg.key $ sudo nano /etc/apt/sources.list.d/jitsi-stable.list #下記の一行を追記 deb https://download.jitsi.org stable/ $ sudo apt update $ sudo apt -d install jitsi-meet #電子カルテから簡単にインターネットからダウンロードできない環境を考えるととりあえず-dでダウンロードオンリーにします #ここでHyper-Vのチェックポインにします。 $ sudo apt install jitsi-meet イン...