#jpblog
Explore tagged Tumblr posts
Photo

New on #JPBlog: why we're in love with the new photo series by @forloveandlemons where real couples share their Sunday mornings in #Skivvies! 💕 This photo was taken by #AsherMoss @basementfix of his stunning girlfriend #MelodiMeadows @babynative 😍❤️ #ForLoveAndLemons
8 notes
·
View notes
Text
その不安、“ノモフォビア”かも?!20の質問で今すぐチェック!

スマホを忘れたり、バッテリーが切れるだけで、イライラ焦ってしまったり、不安になったり、そんな経験ありませんか?
もしそのような経験があるとすると、もしかするとそれはノモフォビア( No-Mobile(phone)-Phobia、携帯電話依存症)かもしれません。重度のスマホ依存症を「ノモフォビア」と呼び、スマホを忘れたり、バッテリーが切れるだけで不安やパニックに襲われちゃう心理のことです。
以下20の質問に答えて、自分がノモフォビアかどうかチェックしてみましょう!質問に「当てはまらない」なら1点、「非常に当てはまる」なら7点とカウントして計算すれば、スマホへの依存度をチェックできます。
⒈スマホが手元になく、情報にアクセスできないと落��着かない。
⒉何かを見たい時に、スマホがないとイライラする。
⒊スマホでニュースや天気予報など生活上で必要な情報が見られない時、ストレスを感じてしまう。
⒋スマホの機能が全く使えなくなってしまったらとても焦ってしまう。
⒌スマホのバッテリーが切れそうになると不安になる。
⒍利用可能なデータ通信量を使い切ってしまうと、おろおろしてしまう。
⒎電波やWi-Fiが入らなくなると、すぐにでも何とかしてインターネットに繋ぎたくなってしまう。
⒏慣れないところにいる時、スマホが手元にないとさらに不安になってしまう。
⒐しばらくスマホを見ていないと気づいたら、途端にすぐにでも見ようとしてしまう。
10.スマホで家族や友人にすぐ連絡が取れなくなったら、きっとものすごく焦ってしまう。
11.家族や友人たちがすぐ自分に連絡できなかったら、とても心配するだろう。
12.スマホでメッセージや電話を受けることができなくなったら、非常に困ってしまう。
13. スマホでいつでも家族や友人と連絡を取っていないと不安になってしまう。
14.誰かが電話をかけてきているかもしれないと思うと、落ち着かなくなってしまう。
15.家族や友人との連絡が突然途切れたら、不安でたまらなくなってしまう。
16.自分のスマホがインターネットに繋げない時、動揺して焦ってしまう。
17.SNSやネットのニュースなどをチェックしていないと、外の世界と溝ができてしまうように感じる。
18.スマホの通知がチェックできなくなったら、とても落ち着かない。
19.スマホでメールのやり取りができないとしたら、とても不安になる。
20.スマホがないと、何をしていいかわからずおろおろしてしまう。
点数を計算して、ノモフォビアの傾向があるかどうかチェックしてみましょう!
21点:ノモフォビアの心配はありません。スマホと健康的な関係を維持できているようです。
22〜60点:軽度のノモフォビアかもしれません。電話を受けられなかったり、Wi-Fiが入らなくなるとちょっと不安になってしまうかもしれません。しかし依存症のレベルではないので、過度の心配は必要ないでしょう。
61〜100点:中度のノモフォビアと言えるかもしれません。スマホの通知やメッセージを漏らさず常にチェックしていませんか?歩きながらスマホを使って友人とおしゃべりしている時、突然電波が悪くなったりしたら、焦って不安になってしまうレベルかもしれません。あまりスマホに依存しないように、ちょっと注意してみてください。
101〜120点:あなたは重度のノモフォビアかもしれません。ちょっとした距離を歩く時も、スマホを見ていないと不安になってしまうレベルではありませんか?朝起きてから寝るまでずっとスマホを使い続け、片時も手放していないのではないでしょうか。今のスタイルを少しだけ見直し、スマホにあなたの生活がコントロールされないようにしてみましょう!
もしあなたがノモフォビアであってもなくても、スマホ動作がもっさりカクカクするのが原因で、スマホに見入る時間が長くなってしまっているのであれば、アプリを「Dr. Booster」に入れてブーストしてみてください。快適なスマホライフを体験できますよ。
更に多くのスマホ活用情報を知りたいときは是非チェック!Dr. Booster公式ファンページへ
参考文献:This Scientific Test Will Tell You How Addicted You Are To Your Smartphone
2 notes
·
View notes
Link
2021年6月23日(太平洋標準時)に開催されたTrailheaDX ’21のセッションの中からSalesforce開発者向けにピックアップした動画を日本語で公開します。 (原文セッションタイトル:Get to know Architect Decision Guides ) Salesforce Developers Japan では Salesforce 開発に関する最新情報を発信しています! ◎チャネル登録はこちらから↓ http://www.youtube.com/channel/UCFG6QAd05vKhxC0ySMH1Cww?sub_confirmation=1 ◎ニュースレター配信登録はこちらから↓ https://forms.gle/9dXsSh9ah4sPFCzt6 ☁ - - - - - - - - ☁ - - - - - - - - ☁ 公式 Twitter https://twitter.com/SalesforceDevJP 公式ブログ https://developer.salesforce.com/jpblogs/ ☁ - - - - - - - - ☁ - - - - - - - - ☁ #Salesforce #セールスフォース #開発 #TDX’21
0 notes
Link
「Salesforce エンジニア白書」を無料公開 この度、Salesforce Developers Japanより「Salesforce エンジニア白書」を公開いたしました。 本レポートは、2021年3月16日から同年4月16日までの間でSalesforce開発者とアーキテクトを対象に実施した「Salesforce開発者アンケート」の結果をまとめたもので、Salesforceで開発の携わるエンジニアの皆様の今を知ることができるレポートとなっています。 この記事では、調査結果の中から注目すべき結果をピックアップしてご紹介しています。 全ての調査結果をご確認頂くには無料配布中の「Salesforce エンジニア白書」をダウンロードしてご覧ください。 Salesforce エンジニアのスキル 多くのSalesforceエンジニアは、JavaScriptやHTML、JavaといったWeb開発に関するスキルを習得していることとが分かりました。また、よく使うフレームワークとしてはjQueryの人気が高く、業界の最先端技術よりは使い慣れた技術を好む傾向があるようです。また、Salesforceプラットフォーム上での開発においても、jQueryが利用できるVisualforceを使った開発が根強い人気を誇っていますが、LWCの活用も進んでいます。 保有している認定資格としては、認定アドミニストレータが最も多く、技術者であってもSalesforceの基本機能への理解が重要視されています。 Salesforce 開発の現場 Salesforceの開発プロジェクトに参加しているエンジニアの内、54.9%が現在システムの内製に関わっています。 また、93.2%の開発者がここ1年間でノーコード開発を活用したと答えており、内製とノーコード開発の浸透率の高さが伺えます。 新型コロナウィルス感染症以降、84.3%のエンジニアが在宅勤務を行っており、半数以上が月の平均残業時間が20時間未満であることから、ライフワークバランスのとれた生活をおくれているようです。 開発者の学習方法 主な学習方法としてはTrailheadと開発者ドキュメント、コミュニティによる技術ブログが活用されています。 また、8割以上がなんらかの社外勉強会に参加しており、年齢が高まるにつれて参加率も上がっています。 Salesforce は非常に多くの機能が提供されているのに加え、年3回のアップデートによる機能強化も実施されるため、継続的な学習が求められる一方で、年齢や役割によって学習方法は変化するようです。 最後に 新型コロナ感染症によって人々の移動が制限され、これまで積み上げてきた開発者同士の繋がりも少しずつ薄れ始めています。同時に、これまで互いの交流によって醸成されてきた技術への探究心やさらなる成長への意欲を見出す機会も薄れつつあります。 「Salesforce エンジニア白書」は、日本のSalesforce開発者を取り巻く環境を俯瞰的に把握し、開発者が今注目している技術やスキル、またスキルアップや学習方法、人材市場における動向など幅広いトピックについての調査結果を公開しています。これにより、以前のような気軽な交流が難しい中でも、Salesforce開発者が自身のスキルや市場価値を客観的に分析する指標となり、現在の仕事やスキルアップにより一層取り組む意欲を再発見することで、開発者コミュニティ全体の発展に貢献できることを願っています。 本調査にご協力頂きましたみなさま、誠にありがとうございました。
0 notes
Link
イベントバスが必要なケースをよくある5つの用途で紹介 オリジナル記事 Do You Need an Event Bus? A Quick Overview of Five Common Uses イベントは、メッセージとも呼ばれ、異なるシステム間で情報を伝達するための優れた手段です。Apache Kafkaは、こうした通信を大規模に処理するように設計されています。 これが業界標準になっている1つの理由は、入力データをすべて最適に活用する効率的な方法を提供していることです。 英語などの言語の価値が高まるのは、多くの人がその言語を話すからであるように、こうしたメッセージは最も一般的なシステムで「理解」される一方で、そうでないメッセージに関して「教える」には多大な努力が必要です。 このブログ記事は公開されており、お互いのことを知らなくても情報を共有できるように、Kafkaはイベントやメッセージを関係者に配信する手段となります。そして、話し言葉と同じように、その言葉を話す人が増えれば増えるほど、その価値は高まっていきます。同様に、異種システムがイベントを交換できるKafkaのような共有イベントバスがあれば、さらに強力になります。 Herokuのアーキテクトとしてトップクラスのお客様をサポートしていると、人とその会社を窮地に追い込むパターンや、きわめて簡単に変更を行うパターンを目にします。この記事では、標準規格に準拠したイベントバスによって実現する(数多くの)パターンのうち、5つのパターンについて手短に紹介します。それぞれのパターンの目的は異なりますが、実装は基本的に同じであるため、簡単で保守性と汎用性の高いものになっています。 これは、イベント駆動型アーキテクチャについて説明するシリーズの記事です。このシリーズの他の記事では、Herokuのコンピューティングを使用してフローを拡張する方法、Work.com組織の複数組織における可視性、および組織間のデータ同期について説明しています。 こうしたパターンの中心となるのが、HerokuとApache Kafkaのコネクターです。どちらもよく知らないという方は、記事の最後にある資料をご覧ください。(また、Heroku Enterpriseのお客様は、Customer Solutions Architectureチームにこれらのトピックに関する詳細なガイダンスをリクエストできます)。 今回の記事では、以下の5つのパターンを取り上げています。 パターン#1:変更を管理する場合(Change Data Capture) パターン#2:連携する場合(統合) パターン#3:すぐに把握する必要がある場合(リアルタイム処理とインサイト) パターン#4:後で必要となる可能性がある場合(データのアーカイブ、バッチ処理) パターン#5:組織のスケーリングが必要な場合(スケーラビリティ) パターン#1:変更を管理する場合(Change Data Capture) データが変更されない場合(おかしなことですが)、この問題はスキップしても構いませんが、変更されてもわからない理由を理解する必要があります。このパターンでは、基本的なユースケースとして、Salesforce組織で何かが変更され、他の多くのサービスで変更内容を把握する必要がある場合を想定しています。サービスが何であるか、または誰が所有しているかを把握していなくても、変更を反映させることができます(言��までもなく、セキュリティを考慮することが重要です)。 たとえば、オンラインストアを運営していて、地域のあるSalesforce組織で在庫が更新されたときに、サイトの検索、レコメンドグラフデータベース、CDNを更新する必要があるとします。Lightning Webコンポーネントは、共有されたKafkaイベントバスから直接更新することもできるので、Salesforce組織内で動作しているアプリであっても、変更後すぐに更新できます。 在庫切れの商品の購入を勧めるような真似は避けたいので、このパターンではタイミングを考慮することが重要になります。また、ロールアウトの同期を維持しながら、品目をパージする機能を備えているかどうかを確認することもおすすめします。オンラインショッピング時に品目は在庫としてあるのに、購入しようとすると消えてしまうような問題を経験したことがありませんか。より適切に処理するには、在庫切れのマークをつけて、順番待ちリストを提供することです。お客様に時間を無駄にしたと感じさせず、他のサイトに流れさせて販売機会を失うこともありません。 最終的に、次のようなアーキテクチャになると考えられます。 詳細情報 Heroku Connect Apache Kafka on Herokuによる複数のSalesforce組織の同期化(ウェブセミナー)(英語) https://devcenter.heroku.com/ja/articles/heroku-data-connectors Elastic Searchアドオン(英語) CDNアドオン(英語) Fastly + Kafka + Elasticsearch(英語) パターン#2:連携する場合(統合) ピーナッツバターとゼリー、コーヒーとドーナツ、あるいはコピーとペーストのように、多くのテクノロジーは相性が良いものです。Apache Kafkaの真の強みは、サービス間やクラウド間でデータを共有すると同時に、各システムの切り離しが可能であることです。これも、標準規格に準拠したオープンソースのソリューションを使用することのメリットです。Apache Kafkaには常に新しいコネクターやツールが開発されており、そのまま利用することも、既存のものを利用して独自に開発することもできます。エコシステムは製品よりも強力です。 イベントを共有バスに送信することで、新しいサービスを追加したいときには、これを共有バスに接続するだけですぐに動作するようになります。この図ではPrivateLink経由でKafkaに接続していますが、これにより、AWS VPC内の別のIPであるかのように安全にアクセスすることができます。また、MuleSoftも接続しており、他の多くのサービスやAPIに接続することができます。 詳細情報 Apache Kafka on Heroku向けPrivateLinkの作成 Heroku Elements(アドオン)(英語) MulesoftとKafkaの接続サンプル(英語) Mulesoftコネクター(英語) MulesoftとHerokuのデータサービスとの接続(英語) パターン#3:すぐに把握する必要がある場合(リアルタイム処理とインサイト) 一部には時間的制約がある変更もあるため、できる限り早急に把握しておく必要があります。たとえば、セキュリティ侵害、商品の出荷(配送)、サービスの停止など、今すぐに対応が必要な問題を考えてみましょう。 リアルタイムのイベントを分析し、通知やダッシュボードを提供するためのアーキテクチャは、以下の図のようになります。イベントがトピックに入ってくると、それを処理し、適切な措置を講じます。イベント数をカウントしてアクションをトリガする量でないか確認することもあれば、単にダッシュボードに集計結果を表示してモニタリングすることもあります。 Kafka Streamsは、このタイプのアプローチを実装する妥当な手段であり(以下のリンクを参照)、アーキテクチャは次のようになります。 詳細情報 HerokuでのKafka Streams Kafka Streamsのアーキテクチャ(英語) 小売でのリアルタイム利用(英語) リアルタイムの他のサンプル(英語) イベントストリームの管理(英語) パターン#4:後で必要となる可能性がある場合(データのアーカイブ、バッチ処理) それでは、今あるこのデータをどこに保存しますか? 多くの企業では、データを一定期間保存したり、オフサイトに保管したりする必要があります。どの企業も、お客様のことをもっと知りたい、データからインサイトを得たいと考えています。これは、そうした方(つまり、私たち全員)を対象としたパターンです。生のイベントをどこかに保存しておく理由は、処理以外にも、イベントを「再生」できるという点があります。バグのため、または新しい方法でデータを処理するために再生が必要となる場合があるかもしれません。どのようなユースケースであっても、このパターンは導入してよかったと思えるものです。 詳細情報 オフサイトデータベースのアーカイブ(英語) TableauとSnowflakeの接続 Kafka用のSnowflakeコネクター Apache KafkaとRedshiftを連携させるコネクターのサンプルアプリ(英語) Apache KafkaとS3、Google Cloud Storageなどの連携(英語) Apache Kafka、Redshift、Metabaseのサンプルアプリ(英語) Kafkaイベントを再生する例(英語) パターン#5:組織のスケーリングが必要な場合(スケーラビリティ) これは大規模なものになりそうです。 サービスが分離されると、サービスは脆弱性が低くなり、俊敏性が高まります。組織の成長に伴って必ず低下するのがチームの「コラボレーションコスト」です。これは、自分のチームの仕事を終わらせる���めに他のチームと話すのに、どれだけの時間を費やしているのかを表しています。つまり、分離することでアプリケーションおよび組織の拡張が可能になります。大規模なモノリシックアプリは、徐々に分離したマイクロサービスに分割することができるうえ、このマイクロサービスは個別にスケーリングできます。また、ここで示したパターンでは、さまざまな地域にあるPrivate Spacesを利用してグローバルにスケーリングしています。Kafkaに送信される変更を取得し、他の地域にあるリモートのRedisキャッシュを更新しています。 詳細情報 Heroku Private Spaces Heroku Redis Apache Kafkaを使用したイベント駆動型マイクロサービス KafkaとRedisを連携させるコネクターのサンプル(英語) まとめ ご覧のように、こうしたパターンは、サービスの接続を行う小規模企業だけでなく、規模拡大に伴って、問題なくチームの動きを迅速化しようとする大規模企業にも、あるいはその中間の企業にも当てはまります。ピースがそろえば、他にもさまざまなユースケースが見えてきます。Kafkaは、より優れたアーキテクチャを実現するための入り口であり、基本的な準備が整えば、可能性は無限大です。 その他の有益なリソース Herokuの神話と魔法(無料動画コース)(英語) Apache Kafkaとは(英語) HerokuでのKafkaコネクターの実行 Herokuのストリーミングデータコネクターのリリース(英語) [すでにHeroku Enterpriseをご利用のお客様は、こちらで会議を設定することができます。Lyricが送ったとお伝えください。] 著者紹介: Lyric Hartleyは、Herokuのカスタマーソリューションアーキテクトです。Herokuの大口顧客が抱える難題の解決と、必要なスケーリングの実現を支援する日々を過ごしています。いつでも新しくて難しい問題を解決することが大好きです。現在の職務に就く前は、Salesforceの開発チームに所属していました。Salesforceの仕組みを理解し、Salesforceの多くのチームがHerokuを使用してより迅速にイノベーションを実現できるよう支援しています。コンピューティングの未来に情熱を注いでおり、人々がすべてのビジネスに共通することではなく、自分のビジネスにとって重要なことに集中できるようにしたいと考えています。また、音楽とビールも大好きです。
0 notes
Link
Learn MOAR Spring ’21:SOQL Builderの更新 オリジナル記事 Learn MOAR with Spring ’21: SOQL Builder Update 最近、SOQLクエリを迅速に作成する新しい方法が導入されました。SOQL Query Builderは、VS Codeの拡張機能であり、誰もがクエリを視覚的に作成、実行して、クエリの結果を調べることができます。クリックでクエリを作成すると、クエリのすぐ隣に結果が表示されます。また、結果を.csvファイルや.jsonファイルに保存することもできます。 すでに多くの方がベータ版の拡張機能をダウンロードし、試してくださっていることを大変嬉しく思います。皆様からのフィードバックをお待ちしておりますので、どうぞよろしくお願いいたします。 ここでは、SOQL Query Builderに追加された新機能や機能強化について簡単にご紹介します。 ビルダーとエディターの切り替え – クエリの作成を開始してから、より複雑なクエリを作成するためにエディターへの切り替えが必要になる場合があります。また、既存のクエリをSOQL Query Builderで開き、項目を追加したい場合もあります。右上にアイコンを追加し、エディターとSOQL Query Builderを簡単に切り替えられるようにしました。 コード補完機能の向上 – エディターでSOQLを直接記述する際のコード補完機能とインテリセンス機能が向上しました。これにより、コードを好む人でも、より効率的にクエリを作成できます。 ビルダーにすばやくアクセス – コマンドパレットの新しいCreate Query in SOQL Builderコマンドを使って、ビルダーで直接クエリを開始できます。 次のターゲットは、WHERE句です。これに対するニーズは承知しており、近々このためのUIを送り出す予定です。他のSalesforce開発者ツールと同様に、SOQL Query Builderも毎週更新されます。この機能は現在ベータ版であり、引き続き改良を重ねているところですので、ぜひフィードバックをお寄せください。現在SOQL Builderをさらに充実させるための新機能を積極的に開発しており、お客様にとって最も重要なことをお聞かせ願えれば幸いです。また、GitHubリポジトリをご覧いただき、 ご意見をお聞かせください。皆様のご協力をお待ちしております。 2021年3月31日までにLearn MOAR Spring ’21の管理者または開発者向けtrailmixを完了すると、特別なコミュニティバッジを獲得できます。また、5名様に200米ドル分のTrailhead Certificationバウチャー1枚をゲットできるチャンスがあります。以下の公式ルールをご覧ください。 Spring ’21リリースの魅力をハッシュタグ#LearnMOARを付けて投稿してください。また、2020年1月29日に開催されるRelease Readiness Liveへの参加申し込みもお忘れなく。 著者紹介 Stephanie Maddoxは、Salesforce Extensions for VS Code担当のプロダクトマネージャーです。2010年3月にExactTarget社に入社し、Salesforce社による買収により2013年7月に正式に同社の一員となりました。Salesforceではカスタマーサクセスとプロダクト管理を担当しています。ボールステイト大学でコンピュータサイエンスの学位を取得し、キャリアの最初の8年間を開発者として過ごしました。Twitter、LinkedIn、Trailheadでフォローすることができます。
0 notes
Link
(この投稿は Aditya Naag Topalli(Salesforce.com) による『Error Handling Best Practices for Lightning Web Components』の翻訳です) エラー処理はどのようなアプリケーションにとても重要であり、設計段階からアプリに組み込むべきです。適切に定義されたエラー処理パターンとベストプラクティスを使用することで、アプリが予想されるエラーと予想外のエラーの両方を一貫して優雅に処理できるようになります。このブログでは、Lightning Web コンポーネントのエラー処理のベストプラクティスについて説明します。Lightning Web コンポーネントのフレームワークは標準ベースなので、ほとんどのエラー処理のベストプラクティスも標準に基づいています。 サーバーサイドのエラー処理 Lightning Web コンポーネントは、サーバー上のデータの存在に依存する UI フレームワークです。Lightning Web コンポーネントを使用して Salesforce のデータを操作する最も簡単な方法は、基本 Lightning コンポーネントと Lightning データサービスによって提供されるワイヤアダプタを使用することです。しかし、データをクライアントに返す前に、カスタムビジネスロジックを実行して複雑な変換を適用する必要がある場合もあり、このカスタムロジックは通常、Apex を使用して記述されます。 Apex のメソッドは、さまざまな例外を投げることができます。これらには、クエリの例外、DML の例外、およびパースや型変換などのビジネスロジックからの一般的な例外が含まれます。Apex コードで処理せずに例外を直接クライアントに送信させることもできますが、予めサーバー側でエラーを処理することで、どの種類のエラーをクライアントに表示するか、どの種類のエラーをバックエンドで処理するかを制御することができます。 エラーを処理する最良の方法は、try-catch ブロックの中でロジックをラップすることですが、リミット例外 (System.LimitException) のように、キャッチブロックでは処理できない種類のエラーもあります。フロントエンドに例外を投げるときは必ず、独自のカスタム例外クラスを作成して、エラーメッセージをカスタマイズしたり、クライアントに送信される例外の詳細を抽象化することをお勧めします。 03} catch (Exception e) {04 throw new CustomException(e.getMessage());08public class CustomException extends Exception { ベストプラクティスとして、エラーを送信するための共通の構造を決め、すべてのバックエンドクラスでそれに従うようにしてください。事前に定義されたエラータイプがあれば、クライアントに返す詳細を簡単に決めることができます。 クライアント側でのエラーの処理 クライアント側で発生する全てのエラーが同じように処理できるわけではありません。ここでは、Lightning Web コンポーネントのエラーの発生源によって、エラー処理の仕組みがどのように変わるのかを見ていきます。 try-catch ブロック try-catch はコード内のエラーを処理する最も一般的な方法ですが、誤用される可能性があります。すべてのコードを try ブロック内に配置することは、ベストプラクティスとは考えられていません。try ブロック内に配置されるコードは、そのコードによって発生するエラーがどのように処理されるかに基づいていなければなりません。異なるコードブロックからのエラーを異なる方法で処理しなければならない場合は、複数の try-catch ブロックを使用してください。また、catch ブロックは、その中で発生する可能性があるエラーのみを処理し、残りはさらに伝搬させるべきです。 覚えておくべきことは、try-catch ブロックは同期コードの例外のみを処理できるということです。setTimeout や Promise のように、非同期コードの実行で例外が発生した場合、try-catch はそれをキャッチしません。以下の例では、エラーが非同期プロセス内で発生したため、キャッチブロックは実行されません。 3 throw new Error('some error');6 console.error("An error occurred"); ワイヤ、命令的呼び出し、プロミスなどの非同期処理によるエラー 前述したように、非同期呼び出しのエラーは、try-catch ブロックの中で呼び出しをラップしてもキャッチできません。setTimeout や setInterval のような時間ベースのイベントの場合は、コールバック関数の内部で try-catch ブロックを使用してエラーを処理する必要があります。 ワイヤード・メソッドの場合、潜在的なエラーの発生源が 2 ヶ所があります。それは、ワイヤアダプタによる値のプロビジョニング中と、プロビジョニングされた結果を処理するためのカスタムロジックの実行中です。値のプロビジョニングでエラーが発生すると、エラープロパティに自動的に格納されます。このプロパティを解析することで、エラーの原因を知ることができ、それに応じて処理することができます。データのプロビジョニングが正常に行われ、データを処理するロジックからエラーを処理したい場合は、以下の例のようにトライキャッチブロック内にロジックを配置します。 02wiredContacts({ error, data }) { 命令的な呼び出しや Promise を使用する場合、エラーを処理する方法は 2 つあります。 1.catch メソッドを使用して、プロミスチェーン全体で発生するエラーを処理します。これには、サーバーからのエラーと then メソッドに書かれたロジックからのエラーが含まれます。catch() メソッドを省略すると、then() メソッドからのエラーを破棄してしまいます。ベストプラクティスとして、すべてのプロミスに catch メソッドがあることを確認してください。下の例では、getContactList と then メソッドの両方で投げられたエラーを catch メソッドが処理しています。 2.非同期関数を呼び出すもう一つの方法に async/await パターンがあり、この場合は同期関数と同じようにコードを try-catch ブロックの中にラップします。 3 let result = await getContactList(); コンポーネントのライフサイクルハンドラ内のエラー コンポーネントのライフサイクルハンドラには、クラスの初期化などを行う constructor() の他、connectedCallback()、renderedCallback() などがあります。ライフサイクルハンドラ内で発生したエラーは、try-catch ブロックでラップすることができますが、プロパティ値を計算する際に発生したエラーは同じように処理することができません。 2export default class PropertyInitErrorExample extends LightningElement { クラスのフィールド/プロパティの値はインラインで計算しないようにし、計算にはゲッターメソッドを使用して、必要に応じてメソッド内のロジックを try-catch ブロックでラップできるようにします。また、コンポーネントのライフサイクル内のエラーを処理するために、errorCallback() ハンドラを使用して境界コンポーネントとしての処理を記述することもできます。これについては、「エラーのライフサイクルと伝播」のセクションで詳しく説明します。 エラーの表示とロギング さまざまな種類のエラーをキャッチする方法を見てきましたが、次は Lightning Web コンポーネントでこれらのエラーを表示する際のベストプラクティスを見てみましょう。 エラー本体のペイロードを理解する エラーを表示する前に、様々なシナリオでキャッチするエラーオブジェクトの構成を理解しておくと便利です。 JavaScript や Web Platform API では、ReferenceError や TypeError などの reject エラータイプを投げます。これらはすべて、以下のプロパティを持つ Error オブジェクトを継承しています。 name – 投げられた例外のタイプ message – エラーメッセージ stack – スタック・トレース 以下にコードスニペットの例と、その結果のコンソール出力を示します。 2 undefinedVariable.toString();5 console.error( ' + e.name );6 console.error( ' + e.message );7 console.error( ' + e.stack ); Apex または Lightning データサービスを使用して Salesforce データにアクセスすると、Fetch API の Response オブジェクトをモデルにした上の例とは異なる構造のカスタムエラーオブジェクトを使用してエラーが表示されます。以下はカスタムエラーオブジェクトに含まれるプロパティの例です。 ok – リクエストの成否 status – レスポンスの HTTP ステータスコード。たとえば内部サーバー エラーの場合は 500。 statusText – ステータスコードに対応するステータスメッセージ body – レスポンスボディ。エラーをスローしたメソッドに応じて異なる。 Apex によって投げられた補足されない例外とカスタム例外については、body プロパティで例外の種類 (body.exceptionType)、エラーメッセージ (body.message)、Apex スタックトレース (body.stackTrace) などの追加の詳細を確認できます。以下にコードスニペットの例とその結果のコンソール出力を示す。 03public static Integer someMethod() { サーバー上のレコードやオブジェクトなどのリソースにアクセスできない場合や、ワイヤアダプタに無効なオプション(無効なレコード ID や必須フィールドの欠落など)を渡した場合、または検証ルールが失敗した場合に、Lightning データサービスでエラーが発生します。Lightning データサービスは、Apex が返すものと非常によく似たカスタムエラーオブジェクトを返しますが、エラーの body プロパティの値は API によって異なります。このオブジェクトには単一のオブジェクトまたはオブジェクトの配列が含まれている場合があるため、ロジックはこれを解析する際に両方のデータ型をチェックする必要があります。以下に例を示します。 01@wire(getRecord, { recordId: '$recordId', fields })02wiredRecord({error, data}) {05 if (Array.isArray(error.body)) {06 this.error = error.body.map(e = e.message).join(', ');10 else if (typeof error.body.message === 'string') {11 this.error = error.body.message; ご覧になったように、エラーオブジェクトの構造はそれぞれのケースで異なります。各コンポーネントで異なる種類のエラーオブジェクトを解析するロジックを繰り返すのではなく、これを行う単一の関数を作成し、それを各コンポーネントのモジュールとしてインポートすることができます。 ベストプラクティスとして、LWC Recipes(Lightning Web コンポーネントのコード例集)にある reduceErrors 関数を使用して、異なる種類のエラーオブジェクトを処理します。この関数は、メッセージプロパティを抽出し、複数のメッセージプロパティが見つかった場合にメッセージを連結します。ここでは、先ほどのコードスニペットを簡略化するためにどのように使用できるかの例を紹介します。 01import { reduceErrors } from 'c/utils';04@wire(getRecord, { recordId: '$recordId', fields })05wiredRecord({error, data}) {07 this.errorMessage = reduceErrors(this.error); しかし、サードパーティのコードを扱う際には、エラーボディのペイロードが若干異なる場合があることを覚えておきましょう。JavaScript の throw 文は、数値や文字列を含む任意の式を投げることができます。そのため、サードパーティのコードからの例外を扱う際には、上で説明したアプローチでは不十分な場合があるので注意が必要です。 エラーの表示 エラーの表示はおそらくエラー処理メカニズムの中で最も重要な部分です。エラーはユーザに意味のある方法で表示されなければなりません。最も推奨される方法は、エラーが発生したポイントの近くでユーザーにエラーを���示することです。例えば、テキストフィールド。ボタンがクリックされたときにエラーが発生する場合や、エラーが複数の箇所で発生した場合は、トーストメッセージがより適切です。 基本 Lightning コンポーネントは、フォームにエラーメッセージを表示するための簡単で一貫性のある方法を提供します。基本 Lightning コンポーネントは、検証状態に応じてフォームコントロールやフォーム自体に CSS クラスを自動的に追加したり削除したりします。reportValidity メソッドと setCustomValidity メソッドを使用して、エラーメッセージをプログラムで制御することができます。 また、エラーメッセージはユーザーフレンドリーであるべきで、エラーが発生したことを示すだけでは役に立ちません。メッセージは、エラーが何であるか、そしてユーザーがそれを修正するために何ができるかを正確に示す必要があります。 一貫したエラー処理と表示メカニズムを持つためには、エラーを表示するための再利用可能なコンポーネントを作成し、すべてのコンポーネントでそれを使用することがベストプラクティスです。これは、LWC Recipes の errorPanel コンポーネントでも利用されています。また、このコンポーネントは先ほど説明した reduceErrors 関数を使用して、すべての形式のエラーオブジェクトを処理し、一貫したユーザーインターフェイスを表示します。以下に例を示します。 1<template if:true={error}2 <c-error-panel errors={error}</c-error-panel エラー・ロギング ユーザーにエラーを表示するだけでなく、コンソールにエラーを出力することもできます。console.error() 関数を使用すると、元のエラーメッセージのコールスタックを記録しつつ、呼び出された console.error() のコールスタックも記録されるため、ベストプラクティスとして使用してください。これは、DevTools コンソールでメッセージの横にある矢印をクリックすると表示されます。 すべてのコンソール ロギング API は複数の引数を受け入れます。捕らえたエラーにさらに情報を追加する必要がある場合は、console.error(‘Unexpected error during some operation’, error) を使用します。 また、より良い追跡と報告の目的のために、可能な限りエラーはサーバーに記録します。これは、本番環境で問題をデバッグする際に最も有用です。アプリケーションの運用が開始されると、エンドユーザが明示的に共有しない限り、ログに記録された出力に開発者がアクセスできないため、 console.error に何の価値もありません。 エラーのライフサイクルと伝播 すべてのエラーが発生源での近くに表示できるわけではなく、また、すべてのエラーがユーザー・インターフェースを持つコンポーネントで発生するわけではありません(サービス・コンポーネントなど)。そのようなエラーを表示するためには、親コンポーネントに伝搬されなければなりません。未処理のエラーはデフォルトではコンポーネント階層を介して伝搬されることになります。 Lightning Web コンポーネントのエラーライフサイクル コードでエラーが発生した場合、Javascript はエラーをキャッチするハンドラを探します。エラーの発生源にできるだけ近いところで処理するのがベストプラクティスです。Lightning Web コンポーネントの場合、処理されていないエラーは子コンポーネントから親コンポーネントに伝搬します。最上位の親コンポーネントがエラーを処理しない場合は、Lightning ランタイムに投げられます。 同期操作によるエラーは、エラーの行番号とスタックトレースを含む “Sorry to interrupt” ポップアップを表示することで、Lightning ランタイムが処理します。エラーはそれ以上ブラウザに伝わりません。ワイヤ関数やプロミスなどの非同期操作によるエラーの場合、エラーはブラウザに伝わり、ブラウザのコンソールに表示されます。またランタイムは、コンテキストに応じて画面にエラーを表示します。例えば、Lightning Experience で Lightning Web コンポネントを実行している場合、非同期エラーは UI に表示されません。しかし、フロー内でLightning Web コンポーネントを実行している場合、フローのランタイムは画面の下部にエラーを表示します。 エラーの伝播 上のライフサイクルで見たように、処理されていないエラーはデフォルトで伝搬します。しかし、上記のいずれかのエラー処理メカニズムを使用する場合、コンポーネントレベルでエラーを処理するか、他のコンポーネントに処理を任せるために伝搬させるかを選択することができます。エラーは、throw キーワードを使用するか、カスタムイベントを使用して伝搬させることができます。throw キーワードを使用すると、使用された時点で関数が停止しますが、カスタムイベントを使用すると、イベントを実行した後の処理を柔軟に決めることができます。throw キーワードを使用してスローされたエラーは、コンポーネントの親によってのみ処理できますが、カスタムイベントを使用すると、階層外のコンポーネントを使用して処理することもできます。 ベストプラクティスとして、低レベルのコンポーネント(サービス・コンポーネント、ユーティリティ関数など)からエラーを伝搬し、高レベルのコンポーネントでエラーを処理します。例外が上位レベルで処理される理由は、下位レベルではエラーを処理するための最も適切な挙動が何かがわからないからです。 ここでは、同じ関数に対し、エラーをスローするものとカスタムイベントを発生させるものの 2 つのバリエーションを示します。 01export default class Hello extends LightningElement {04 divide_with_throw(a, b){06 throw new Error('Cannot divide by 0'); 12 divide_with_event(a, b){14 const selectedEvent = new CustomEvent('error', { detail:'Cannot divide by 0' });15 this.dispatchEvent(selectedEvent); 次のステップは、これらのエラーを親コンポーネントで処理することでしょう。 カスタムイベントを使用している場合は、それらのイベント用のイベントハンドラを書けばよいのです。カスタムイベントは実際にはエラーではないので、catch ブロックを使って捕捉できないことに注意してください。 カスタムエラーを投げる場合は、上記のエラー処理メカニズムを使用して個々のエラーをキャッチするか、errorCallback() ハンドラを使用して未処理のエラーとカスタムエラーをすべて捕捉することができます。 errorCallback() は、そのツリー内のすべての子孫コンポーネントからのエラーをキャプチャするライフサイクルハンドラです。子孫のライフサイクルハンドラや、コンポーネントの HTML テンプレートで宣言されたイベントハンドラ内で発生したエラーを捕捉します。errorCallback()フックについて覚えておくべきことがいくつかあります。プログラムで追加されたイベントハンドラ(addEventListener など)は捕捉されません。エラーがキャッチされると、フレームワークは DOM からエラーを発生させた子コンポーネントをアンマウントします。子孫コンポーネントで発生したエラーはキャッチしますが、自身のコンポーネントで発生したエラーはキャッチしません。 ベストプラクティスとして、errorCallback() を実装する境界コンポーネントを作成し、その中に機能コンポーネントを埋め込みます。ここでは、エラーが errorCallback() によりキャッチされ、errorPanel 境界コンポーネントを使用して表示する例を示しています (先ほど説明した reduceErrors 関数を使用しています)。 2 <template if:true={this.error}3 <c-error-panel errors={this.error}</c-error-panel5 <template if:false={this.error}6 <!-- YOUR COMPONENT -- 1import { LightningElement } from 'lwc';3export default class Boundary extends LightningElement {4 errorCallback(error, stack) { 正しいバランスを見つける すべてのエラーがコンポーネント内で処理される必要があるわけではないことを覚えておくことが重要です (低レベルのコンポーネントのエラーなど)。エラーを捕捉せずに放置しておくと、エラーの根本原因を特定して修正するのが簡単になることもあります。これは、開発やテストの段階で特に有用です。しかし、エラーをキャッチするタイミングとキャッチしないタイミングの適切なバランスを見つけるのは難しいかもしれません。ここではそのヒントを紹介します。 アプリケーションを失敗させることは、エラーをうまく処理できないよりも、常に望ましいことです。 外部やサードパーティのコードを扱う際には、常にエラーを適切に処理するようにしてください。 サーバへの呼び出し、サードパーティのライブラリ、外部サービスへの呼び出しなど、アプリケーションの境界点でのエラーを常に処理するようにしてください。 必要に応じて自分のコードでエラーを投げることを恐れないでください。 まとめ このブログでは、コードのどの部分で発生するかによって、エラーを処理する方法が異なることを見てきました。また、エラーオブジェクトの異なるフォーマットと reduceErrors 関数がエラーメッセージの抽出にどのように役立つか、境界コンポーネントを作成することで未処理のエラーからコンポーネントツリーを保護する方法についても見てきました。最後に、イベントと throw 文を使用してコンポーネント階層にエラーメッセージを伝搬させる方法を紹介しました。サンプルギャラリーでは、ベストプラクティスを実践しているアプリを見ることができます。 さらに学習を進めるために、いくつかの追加リソースをご紹介します。 Apex の例外 Handle Server Errors[英語] コンポーネントエラーの処理 JavaScriptエラータイプ Lightning データサービスでのエラー処理 著者について Aditya Naag Topalli は、Salesforce リードデベロッパーエバンジェリストです。彼は、Lightning Web コンポーネント、Einstein Platform Services、およびインテグレーションにフォーカスしています。技術的なコンテンツを執筆し、世界中のウェビナーやカンファレンスで頻繁に講演を行っています。 Twitter @adityanaag
0 notes
Link
(この投稿は Nathan Totten (Salesforce.com) による『Introducing Salesforce Code Builder』の翻訳です) ここ 3 年の間に、 Salesoforce プラ […] The post Salesforce Code Builder を発表 appeared first on Salesforce Developers Japan Blog.
0 notes
Link
Salesforce 向け CircleCI Orbs を公開
0 notes
Link
本記事ではプラットフォームイベントと LWC を使ったシンプルなチャットコンポーネントの作成例を紹介します。 このコンポーネントでは同じ Salesforce 組織にログイン中の二人が、チャット形式での会話を開始できます […] The post LWCとプラットフォームイベントで実現するリアルタイムチャット appeared first on Salesforce Developers Japan Blog.
0 notes
Link
この記事では、郵便番号から住所を自動入力するシンプルで便利な Lightning Web コンポーネント (LWC) を例に挙げ、LWC 開発の魅力とポイントに迫ります。LWC の開発に不慣れ方でも安心してください。この […] The post 郵便番号の入力を Lightning Experience で実現する LWC 開発! appeared first on Salesforce Developers Japan Blog.
0 notes
Link
今年も Salesforce では、一足早い春を Spring ’20 リリースと共に迎えました。 プレリリース期間中のデベロッパーエバンジェリスト達は、素晴らしい最新の機能を活かしたサンプルアプリケーション […] The post Spring ’20 リリース情報とサンプルギャラリーのアップデート appeared first on Salesforce Developers Japan Blog.
0 notes
Link
Evergreen: Salesforce Platform 向け サーバーレス Functions および Customer 360 向けコンピュート すぐれた統一感のあるデジタルエクスペリンスは、顧客・パートナー・従業員にとって、すばらしいものであり、そういった最新のエクスペリエンスを構築するには、Customer 360 のデータとビジネスロジックにシームレスにアクセスできる必要があります。 それを実現する Salesforce Evergreen を発表できることを嬉しく思います。これは、フルマネージドな Kubernetes 上に構築されたサーバーレス機能で、オープンなプログラミング言語のサポート、一般的に利用される高性能なデータストアを提供する Customer 360 Platform の新しい機能です。 Evergreen は、顧客が期待される、親密で魅力的なデジタルエクスペリエンスを構築するための最良の方法です。 Evergreen は、開発チームの生産性を高めるために、以下の技術とアーキテクチャパターンをサポートしています: Functions-as-a-Service:ビジネスロジックやイベント処理を、Node.js、Java、Apex といった開発言語、および、その開発言語のエコシステムで構築します。Funcstions は、Apex から直接、もしくは、様々な呼び出しタイプとイベントソースをハンドルする Platfrom Events から呼び出されます。 Microservices: 小規模でアジャイルなチームにより、複雑で有益なデジタルエクスペリエンスを構築し、頻繁に改善される、HTTP ベースのサーバーレスアプリケーションや API の構築。サービスと Functions はサーバーレスであり、利用されていないときはリソースを消費せず、トラフィックの増加により、自動的にエラスティックにスケールします。 マネージドデータストア: Postgres、Apache Kafka、Redis は、高パフォーマンスで永続化するデータ保管場所やリアルタイムイベント管理を提供し、Salesforce Data API を補完します。 業界標準を考慮し、これらの機能は、顧客コンテキスト上に構築される Salesforce データモデル駆動で、省コードなコンポーネントで構成されています。Evergreen は Salesforce プラットフォームの一部で、追加の認証やネットワーク設定は必要ありません。 たとえば、開発者は Apex から関数を直接呼び出し、組織のコンテキストでロジックを実行、クエリー、更新などの操作ができます。 Evergreen は Kubernetes をベースとし、Salesforce が運用するフルマネージドなサーバーレスサービスを提供することにより、スケーラブルなコンテナテクノロジーの管理容易性と、高い利用性のバランスを実現します。 このサービスを利用すると、インフラストラクチャの運用ではなく、イノベーションに集中できます。 Evergreen は、アプリケーション、Function、サービスを一般的なオープンな開発言語、開発ツール、開発技術を使って構築できるので、すべての開発チームに、オープンな Salesforce 開発環境を提供します。 Dreamforce 2019 の Developer Keynote では、Caesars Entertainment のような Salesforce のお客様が、 Evergreen を使用して、最新のゲストチェックインエクスペリエンスを構築する方法を紹介しました。キーノートのデモでは、Lightning Platform を使用して、清掃と部屋の準備を管理する従業員向けの iOS アプリをすばやく構築し、Evergreen で実行されるイベント駆動型 Function 機能でシームレスに拡張しました。清掃スタッフがアプリを使用して部屋を準備完了とマークすると、プラットフォームイベントが、Node.js で作成された Function をよびだし、ゲストのコンテキストで、リアルタイム通知を送信し、ゲストにアーリーチェックインの準備が完了したことを知らせます。 宿泊者のチェックアウト後には、請求書の明細を作成する別の Function を呼び出します。Node.js で作成された Function は、請求書の明細と、npm PDF モジュールを使用して、請求書を作成します。以下は、CloudEvent が追加データを取得し、PDF を作成し、宿泊者の予約情報のリンクをPDFに追加するサンプルです。 Functions は、利用されていない状況の時には休止状態となり、なにかしらの呼び出しが発生した場合や負荷が発生した場合には、自動的にスケールします。Functions は、 Cloud Native Buildpacks から簡単にビルドされ、開発者は、数多くのサポートされている開発言語で、パッケージやライブラリを利用して、開発することができます。 Evergreen は、Heroku のスケーラブルなコンテナランタイムと、 Lightning ツールと機能を活用できる高パフォーマンスのデータストアを統合している Salesforce プラットフォームへの最新の機能追加です。サーバーレスのエラスティックなコンテナ技術と、顧客データとビジネスロジックへのシンプルなアクセス手段との組み合わせにより、Salesforce は、顧客、パートナー、従業員にとって、差別化されたデジタルエクスペリエンスを構築、および、運用するすばらしい場所になります。 Evergreen デベロッパープレビューは2月にリリースされる、Spring ’20 で利用可能になる予定です。 ぜひ、Evergreen の最新情報をお届けするメールにサインアップしてください。 また、Dreamforce Developer Keynote の録画では、Evergreen のデモンストレーションをご覧いただけます。#DF19 にご参加いただいている場合には、Evergreen の詳細を入手するために、(Moscone Westの)Trailhead エリア内の Platform Park にある Evergreen ブースにお越しください。また、Evergreen に関する Dreamforce ブレークアウトセッションへもご参加ください。
0 notes
Text
Twitter、Instagramのアカウントが乗っ取られる前に! さぁ!プロフィール設定を見直そう!

TwitterやInstagramでライフスタイルをシェアするのは楽しいですよね。昨今SNSでのプライベートの設定について注意が促されてはいますが、情報を知られてしまうことも無きにしも非ず。TwitterやInstagramのアカウントの設定を見直して、安心を手に入れましょう!
Twitterのプロフィール設定はホーム画面の左上の ボタンで
⒈ 自分のツイートを保護する:設定ボタンの「プライバシーとコンテンツ」をタップするとプライバシーに関する設定ができます。例えば「ツイートを非公開にする」にチェックを入れると、フォローを許可したフォロワーのみにあなたのツイートが表示されます。

⒉ 全ユーザーからメッセージを受け取らない:「全ユーザーからメーッセージを受信」にチェックを入れなければ、知らない相手からの連絡を防ぐことができます。

⒊ 更に細かく設定したいなら:この設定画面には「自分を画像にタグ付けすることを許可」、「メールアドレスの照合と通知を許可する」、「電話番号の照合と通知を許可する」、「ブロック済みアカウント」、「ミュートしているアカウント」など、プライベートな詳細をカスタマイズして設定できます。

Instagramの安全とプライベート設定
⒈「非公開モード」を設定すると◎:自分のアカウントを「非公開」か「公開」か設定することができます。非公開モードならフォロワーだけが動画や写真を見られます。あなたのフォロワーでないなら、あなたの投稿は見られません。
もしも「公開モード」だと、アカウント検索やハッシュタグからあなたのデータを見ることができてしまうのです。

⒉ ストーリー設定:「設定」の中で「ストーリー」の設定ができるんです。「次の人にストーリーを表示しない」 のボタンから公開したくない相手を選べるので、選択した相手はあなたの投稿を見られなくなります。

TwitterとInstagramの設定を見直して、安全に楽しんでくださいね!
スマホに関する、かなり使える情報が満載のDr. Booster公式ファンページ!
こちらもぜひチェックしてみてください。
1 note
·
View note
Text
LINEのスタンプの種類が多すぎていつも相手に何を送るか悩んでしまう…そんな時は、LINEに自動でオススメしてもらいましょう!

メールよりも簡単にメッセージのやり取りができるLINEは、今や日常には欠かせないツールですよね。
でも会話の時、相手にぴったりのスタンプを選びたいのに、LINE内のスタンプが多すぎて、どれにすればいいのかわからない…何ともしっくりこない…なんてことありませんか?実は、そんな時LINEは、打った文字に対して、自動でスタンプをオススメしてくれるのです。これならいつも何のスタンプ送ろうと悩んでいた時間が短縮できちゃいます!とても便利なスタンプの「予測変換候補」機能についてご紹介します。
ステップ1 「LINE」の「設定」を開く

ステップ2 「スタンプ」をタップ

ステップ3 「サジェスト表示」をタップ

ステップ4 「サジェスト表示」にチェックを入れる

ステップ5 予測変換時に使用する言語を選ぶ(「英語」、「日本語」、「中国語(繁体字)」にチェックを入れると、この3ヶ国語を使っている時全てにおいて予測変換をしてくれます)

設定後、早速予測変換を試してみましょう。

予測変換機能はとっても便利で重宝する機能ですよ!「サジェスト表示」を設定して、LINEのおしゃべりをより一層楽しんでくださいね!それから、LINEの動きが遅いと感じたらDr.Boosterから起動させてみてください。これでスマホの動作がサクサク快適に!更に多くのスマホ活用情報を知りたいときは是非チェック!Dr. Booster公式ファンページへ
※本ブログに記載されている製品名、会社名は、それぞれ各社の商標または登録商標です。
1 note
·
View note
Text
ポケモンGOをプレイしているとバッテリーの消費が激しい!?スマホのバッテリーをもっと長く使うための3つのポイント
皆さん最近ポケモンGOはプレイしてますか?外に出かけると公園やビルの近くでポケモンをゲットしている人をよく見かけるようになりましたよね。けど、ポケモンGOをプレイしているとバッテリーの消費が激くなったと感じたりしませんか?
今回はどうすればスマホのバッテリーをもっと長く使えるのか3つのポイントをご紹介します。
1⃣️充電が満タンになったらケーブルを抜こう
皆さん、スマホの充電が100%になっても、そのままケーブルにつなげて充電してませんか?ほとんどのスマホはリチウムイオンバッテリーというのを使っており、100%の状態で充電し続けると、逆にバッテリーの寿命を短くしてしまう可能性があります。なのでバッテリーの寿命を延ばしたい場合、充電は40%〜80%がオススメです。
2⃣️純正バッテリーを使おう
安いからといって純正バッテリーでない、互換性を持っているバッテリーを使用してはいけません。純正品よりも品質が劣っている可能性が高く、純正ではないバッテリーを使用するとスマホが過熱しやすくなります。バッテリーを交換するときは純正バッテリーを使いましょう。
3⃣️熱を持たせない
最後に、スマホを充電する時に重要なことがもう一つあります。それはスマホに熱を持たせないことです。充電の時だけでなく外出時も注意してください。この夏うっかり車の中に置き忘れたなんてことも注意が必要です。高温はスマホのバッテリーの寿命とバッテリーの品質に影響を与えます。気をつけましょう。
今回紹介した3つのポイントをよく理解して、スマホのバッテリーをもっと長く使っていただければと思います!他にもスマホに関する情報を知りたい方はぜひ公式ファンページをチェックしてください!
參考資料:You've been charging your smartphone wrong、How to properly charge a phone’s battery: stop charging from zero to 100% and other tips
1 note
·
View note