javascript - 很想问,前后端分离具体的实现是怎么样呢?
前后端分离是否前端的端口和后端的端口不一样?如果一样的话。那么如果像阿里的前后端分离,中间有过度的nodejs作为中间缓存和页面的渲染方面的,但是我现在的前端框架很多能够提供足够的api来使用户不需要再一层页面渲染,那么我直接用nodejs做数据缓存,那么是否意味着大量的http短链接转移(nodejs到java或php之类的做数据操作层),一直没真正理解到底什么事前后端分离,而且这样子的前端不是基本都被直接下载下来了,我指直接CTRL+S就能保存下来整个前端,虽然很多有做足够多的JS uglify使得即使拿走了也很难修改,但是我觉得整个的业务逻辑后端再做就可以,那是不是很赔本?我指的是SPA,因为现在很多项目基本都是靠SPA纯异步来做的。求解答!
回复内容:
前后端分离是否前端的端口和后端的端口不一样?如果一样的话。那么如果像阿里的前后端分离,中间有过度的nodejs作为中间缓存和页面的渲染方面的,但是我现在的前端框架很多能够提供足够的api来使用户不需要再一层页面渲染,那么我直接用nodejs做数据缓存,那么是否意味着大量的http短链接转移(nodejs到java或php之类的做数据操作层),一直没真正理解到底什么事前后端分离,而且这样子的前端不是基本都被直接下载下来了,我指直接CTRL+S就能保存下来整个前端,虽然很多有做足够多的JS uglify使得即使拿走了也很难修改,但是我觉得整个的业务逻辑后端再做就可以,那是不是很赔本?我指的是SPA,因为现在很多项目基本都是靠SPA纯异步来做的。求解答!
前后端分离的意思是让负责写展示代码的人和写业务逻辑代码的人能够尽量少的交流。尽量确定尽量少的接口,两部分人的开发可以相互独立,不需要其中一个写完才能写另一个,可以独立测试。
就是一个大的项目如何分成两个互不相关的部分,两部分人各自写,其中的交流越少越好,理想的是不交流但是不可能,然后各自写好了放到一起就可以运行了。而且还要求这两群人掌握的技能越少越好,降低人力的成本,如果每个人都懂前端和后台就不叫前后端分离了,而是叫模块化吧。当然最好还是有代码复用,易于维护,代码效率高等要求。
这个似乎没有特别好的实现方案。
楼主说的其实很好呀,各种目前的方式都看到了其中的缺点。反编译抄袭代码的问题,这个早就有了呀。
http://www.yitaomin.cn/?p=187
整站ajax,就是前后端分离。以前说的不分离,是用php smarty模板啊,java什么模版这种,前端要动后端代码。
前后端分离:后端返回JSON,前端获取JSON组织成HTML输出到页面.
不过页面初始化的时候最好还是通过后端直接输出HTML.
需要注意的是,AJAX和后端返回JSON对SEO来言显然是不友好的.
前后端分离 就是后端负责接口 前端负责所有页面展示逻辑及请求接口获取数据然后输出HTML
但是一般前端请求接口都是通过ajax请求的 这个对SEO很不友好,因为页面的渲染都是靠JS拼接的,在客户端渲染,所有为了解决这个问题 可以使用NODEjs做中间层 同过node去请求接口 在服务端渲染html 这样就可以解决此类问题。
就是前后端分开开发互不干扰啊,现在前端的代码都是build过的,下载了也没用啊
通常说的前端是指访问者能够看到的内容,后端是访问者看不到的内容。或者更简明的回答你,前端就是html,css,javascript。
此外我觉得好好学习很重要,听到几个名词就到处用,说真心话,搞得我根本不知道你想问什么。
阿里、淘宝、京东、新浪、网易、百度这种级别的网站所说的前后端分离和通常网站开发所说的前后端分离不是一种概念。
前后端分离有很多种实现方式。我这里只说我这里目前用的:前端跟后端纯交互数据,后端提供支持jsonp的数据接口给前端,前端有前端的nginx服务器,后端有后端的nginx+tomcat服务器独立部署发布。
前后端分离,就是前端专注自己的开发,后端只要提供接口就可以,目前常见的app开发基本都是,app端开发和后台开发基本分离。
前端用AngularJS
后端用Php等服务器语言
前后端用restfulAPI接口定义通讯
如何用AngularJS构建管理后台
JWT在前后端分离中的应用与实践

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

Java는 초보자와 숙련된 개발자 모두가 배울 수 있는 인기 있는 프로그래밍 언어입니다. 이 튜토리얼은 기본 개념부터 시작하여 고급 주제를 통해 진행됩니다. Java Development Kit를 설치한 후 간단한 "Hello, World!" 프로그램을 작성하여 프로그래밍을 연습할 수 있습니다. 코드를 이해한 후 명령 프롬프트를 사용하여 프로그램을 컴파일하고 실행하면 "Hello, World!"가 콘솔에 출력됩니다. Java를 배우면 프로그래밍 여정이 시작되고, 숙달이 깊어짐에 따라 더 복잡한 애플리케이션을 만들 수 있습니다.

간단해진 Java: 강력한 프로그래밍을 위한 초보자 가이드 소개 Java는 모바일 애플리케이션에서 엔터프라이즈 수준 시스템에 이르기까지 모든 분야에서 사용되는 강력한 프로그래밍 언어입니다. 초보자의 경우 Java의 구문은 간단하고 이해하기 쉬우므로 프로그래밍 학습에 이상적인 선택입니다. 기본 구문 Java는 클래스 기반 객체 지향 프로그래밍 패러다임을 사용합니다. 클래스는 관련 데이터와 동작을 함께 구성하는 템플릿입니다. 다음은 간단한 Java 클래스 예입니다. publicclassPerson{privateStringname;privateintage;
