Laravel 프로젝트 에서 timeAgo 필드 언어 전환 개선 방법 예시
우리 의 과거 Laravel 프로젝트 에 서 는 time 를 자주 사용 해 야 했다.ago 와 같은 필드 를 우리 가 잘 아 는 로 컬 언어 로 바 꾸 면 실현 할 수 있 는 방식 이 많 습 니 다.예 를 들 어 timeago 의 보조 함 수 는 이 를 로 컬 로 변환 하거나 carbon 의 diff ForHumans 함 수 를 사용 하여 로 컬 언어 로 대체 하여 실현 합 니 다.
과거 에 우리 가 작성 한 코드 는 이렇게:
이러 하 다
그러나 우 리 는 그것 을 중국어,번 체 중국어,일본 또는 한국어 로 바 꿔 야 할 때 다음 과 같은 여러 가지 유사 한 방법 을 만들어 야 한다.
time_ago_CN //
time_ago_HK //
time_ago_JP //
time_ago_KO //
프로젝트 가 국제 화 되 거나 더 많은 언어 를 지원 해 야 할 때 불편 합 니 다.그러나 최근 에 carbon 의 공식 문 서 를 뒤 적 였 을 때 carbon 은 다 언어 를 지원 하 는 것 을 발 견 했 습 니 다.즉,위의 일 은 carbon 이 모두 실현 되 었 습 니 다.(이것 은 우리 의 기술 빚 에 또 한 몫 을 더 해 주 었 습 니 다)만약 우리 가 중국 어 를 지원 하고 싶다 면,우 리 는 모델 에 상기 방법 을 추가 할 수 있다.
public function createdAt($locale = 'zh')
{
Carbon::setLocale($locale);
return $this->created_at->diffForHumans();
}
그리고 호출 방식 은 다음 과 같다.
//
$user->createdAt(); //9
//
$user->createdAt('zh_HK'); //9
//
$user->createdAt('ja_JP'); //9ヶ
만약 당신 이 그 를 더욱 유 니 버 설 화 시 키 고 싶다 면,보조 함수 로 포장 하 는 것 을 권장 합 니 다.
function time_ago($time, $locale = 'zh')
{
$time = $time instanceof Carbon ? $time : Carbon::parse($time);
Carbon::setLocale($locale);
return $time->diffForHumans();
}
carbon 언어 지원:https://carbon.nesbot.com/contribute/translate/carbon 2.0 은 기본적으로 laravel 5.8 에서 지원 합 니 다.이 버 전보 다 낮 으 면 다음 과 같은 방식 으로 carbon 2.0 을 사용 할 수 있 습 니 다.예 를 들 어 laravel 5.6.
composer.json 에 다음 옵션 을 추가 합 니 다.
{
"require": {
"nesbot/carbon": "2.24.0 as 1.39.0",
"kylekatarnls/laravel-carbon-2": "^1.0.0"
}
}
그리고 coposer update 를 실행 하여 의존 항목 을 업데이트 합 니 다.
composer update
마지막 으로 carbon 공식 문서 주소 보 내기:https://carbon.nesbot.com/총결산
이상 은 이 글 의 모든 내용 입 니 다.본 고의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 참고 학습 가 치 를 가지 기 를 바 랍 니 다.여러분 의 저희 에 대한 지지 에 감 사 드 립 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.