我有非常基本的设置,即 getServerSideProps 和Vercel生产中的 Sentry 错误日志记录
export const getServerSideProps = async () => {
// some api call
if(error) {
throw new Error("Something went wrong")
}
return {
props: {
data
}
};
};
Run Code Online (Sandbox Code Playgroud)
_error.js看起来像这样
import * as Sentry from '@sentry/nextjs'
import { NextPageContext } from 'next'
import NextErrorComponent, { ErrorProps as NextErrorProps } from 'next/error'
const CustomErrorComponent = (props: NextErrorProps) => {
return <NextErrorComponent statusCode={props.statusCode} />
}
CustomErrorComponent.getInitialProps = async (contextData: NextPageContext) => {
await Sentry.captureUnderscoreErrorException(contextData)
console.log(contextData.res?.statusCode) // …Run Code Online (Sandbox Code Playgroud) 我在下面找到了一些讨论这个场景的线程.
但是仍然很难找到,如果有任何推荐的数据结构设计.我看到一个多写库firebase-multi-write,它说你在大多数情况下可能不需要这个.
但我认为我确实需要这个,我的情况是:3个用户
/users/A : {credit:20}
/users/B : {credit:3}
/users/C : {credit:10}
Run Code Online (Sandbox Code Playgroud)
每个用户可以窃取相互学分都在同一时间,
现在我需要为每个用户更新信用以保持这种一致性,这样每个窃取操作本质上都是原子的.
在保持Java数据完整性的同时,处理此类场景的最佳方法是什么?
我想了解第三方的Javascript代码.但我无法弄清楚以下编码风格的用途.
function A(){
}
A.Prop = '23';
A.generate = function(n){
// do something
}
Run Code Online (Sandbox Code Playgroud)
然后它只是用作:
A.generate(name);
Run Code Online (Sandbox Code Playgroud)
有人可以解释这段代码在做什么.我理解一些OO Javascript,但我想知道这是否是任何其他形式的扩展具有新属性的对象.虽然我没有看到任何"新"关键字被使用,但创建一个对象.
有任何想法吗 ?
谢谢,
尝试使用 Android TextInput 组件,但是当文本长于组件大小时,文本会在开始时被截断。
有什么方法可以让我从头开始渲染文本或在开始时设置光标。并且仅在聚焦或选择此组件时将光标设置为结束?
我的 MainActivity 设置如下所示:
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.host.HostActivity">
<fragment
android:id="@+id/mainNavigationFragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:navGraph="@navigation/nav_graph" />
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigationView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/windowBackground"
app:labelVisibilityMode="labeled"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:menu="@menu/main_nav_menu" />
</androidx.constraintlayout.widget.ConstraintLayout>
Run Code Online (Sandbox Code Playgroud)
底部导航有 3 个选项卡,只有在执行一些初始身份验证和设置用户调用后才能显示。
在让用户开始使用底部导航视图之前,显示加载/设置用户屏幕的最佳方式是什么?
我想到的一种方法是延迟 Activity 中 NaHostFragment 的设置,直到所有设置完成。所以基本上切换mainNavigationFragment和的可见性BottomNavigationView,直到设置完成。
还有其他想法吗?
将 mayBe 类型与对象字面量的 Optional props 混合
type Response = {
data?: string;
}
function length(): ?string {
return undefined;
}
function test(): Response {
const data = length()
return {
data
}
}
12: data ^ Cannot return object literal because null or undefined [1] is incompatible with string [2] in property `data`.
References:
5: function length(): ?string {
^ [1]
2: data?: string;
^ [2]
Run Code Online (Sandbox Code Playgroud)
android ×2
android-architecture-navigation ×1
firebase ×1
flow-typed ×1
flowtype ×1
java ×1
javascript ×1
namespaces ×1
next.js ×1
react-native ×1
vercel ×1