Angular 6 + Routes Resolver = 404 страницы в производстве - PullRequest
0 голосов
/ 11 января 2019

Я новичок в Angular Community с рельсов; Я работаю над сайтом, где я могу публиковать тематические исследования на моем клиентском веб-сайте. До сих пор я люблю angular, но я сталкиваюсь с проблемой, которая волнует меня немного. Проблема, которую я не могу использовать гиперссылки, чтобы ссылаться на любой из проектов. Например, если вы нажмете this , приложение вернет статус 404, но если вы начнете с корневой страницы , все будет работать без проблема.

Решения, которые я пробовал

  1. Добавление распознавателя к маршруту для извлечения данных перед загрузкой страница; это работает, но гиперссылка по-прежнему отсутствует.

Может ли кто-нибудь помочь мне выяснить, что я пропускаю или делаю неправильно;

Ниже мой код; Любая помощь будет оценена

  1. Project.service.ts

    import { AngularFirestore } from 'angularfire2/firestore';
    import { Observable, of } from 'rxjs';
    import { map,  } from 'rxjs/operators';
    import { Injectable } from '@angular/core';
    import { Project } from '../../models/project';
    import { HttpClient } from '@angular/common/http';
    import { Post } from '../post';
    
    
    
    
    @Injectable()
    
    export class ProjectService {
    
        ProjectListRef: Observable<any[]>;
        featuredProjectList: Observable<any[]>;
        posts: Array<Post>;
   
    
        constructor( private database: AngularFirestore, private http: HttpClient) {
            // Link For All Projects Page
            const allProjectsListLink = this.database.collection<Project>('projects', ref => ref.orderBy('company_name'));
    
    
    
            // Link For Featured Project Page
            const featuredProjectsListLink = this.database.collection<Project>('projects', ref => ref.limit(5));
    
    
    
this.ProjectListRef = allProjectsListLink.snapshotChanges()
            // using map pipe
            .pipe(map( actions => {
                return actions.map(a => {
                    // Get Document Data
                    const data = a.payload.doc.data() as Project;

                    // Get Document Id

                    const id = a.payload.doc.id;

                    return {id, ...data};

                });
            }));
    
      this.featuredProjectList = featuredProjectsListLink.snapshotChanges()
      // using map pipe
      .pipe(map( actions => {
      return actions.map(a => {
      // Get Document Data
      const data = a.payload.doc.data() as Project;

      // Get Document Id

      const id = a.payload.doc.id;

      return {id, ...data};

      });
      }));


      }


        getAllProjects() {
            return this.ProjectListRef;
        }
    
        getFeaturedProjects() {
            return this.featuredProjectList;
        }
    
        getProject(id: string) {
            console.log(id);
            return this.database.collection('projects').doc(id)
            .ref.get().then( doc => doc.data() );
          }
    
    }
  1. Project.component.ts

        import { Component, OnInit, Injectable, Inject } from '@angular/core';
                import { Router, ActivatedRoute } from '@angular/router';
                import {  tap } from 'rxjs/operators';
                import { ProjectService } from '../../app/services/project.service';
                import { AngularFirestore } from 'angularfire2/firestore';
                import { Project } from '../../models/project';
                import { DOCUMENT } from '@angular/common';
    
            @Injectable()
            
            @Component({
              selector: 'app-project-page',
              templateUrl: './project-page.component.html',
              styleUrls: ['./project-page.component.scss']
            })
            export class ProjectPageComponent implements OnInit {
            
              project: Project;
              projectId: any;
              projectRef: any;
            
            
              constructor(@Inject(DOCUMENT) private document: any, private router: Router,
                          private route: ActivatedRoute,
                          public database: AngularFirestore,
                          private projectService: ProjectService
                        ) {
            
                  }
            
            
              ngOnInit() {
            
                  // print out the data from the route resolver
                  this.route.data.pipe(
                    tap(console.log))
                    .subscribe(
                      data => this.project = data['project']
                  );
            
              }
            
              goToWebsite(url) {
                this.document.location.href = url;
              }
            
            
            
            }
 3. **ProjectResolver.ts**

import { ProjectService } from './../../app/services/project.service';
import { Project } from './../project';
import { Resolve, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';
import { Observable } from 'rxjs';
import { Injectable } from '@angular/core';
    
    
    @Injectable()
    
    export class ProjectResolver implements Resolve<Project> {
    
        constructor(private projectService: ProjectService) {
    
        }
    
        resolve(
                route: ActivatedRouteSnapshot,
                state: RouterStateSnapshot): Observable<Project>|Promise<any> {
                return this.projectService.getProject(route.params['id']);
                }
    
    
    }
  1. Маршруты применения

import { AddLeadPageComponent } from './add-lead-page/add-lead-page.component';
import { GoogleAdsPageComponent } from './google-ads-page/google-ads-page.component';
import { WebAppsPageComponent } from './web-apps-page/web-apps-page.component';
import { BrandedWebsitesPageComponent } from './branded-websites-page/branded-websites-page.component';
import { ServiceOverviewPageComponent } from './service-overview-page/service-overview-page.component';
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { HomePageComponent } from './home-page/home-page.component';
import { AboutPageComponent } from './about-page/about-page.component';
import { BlogPageComponent } from './blog-page/blog-page.component';
import { WebServicesPageComponent } from './web-services-page/web-services-page.component';
import { SEMPageComponent } from './sempage/sempage.component';
import { ContactPageComponent } from './contact-page/contact-page.component';
import { AllProjectsPageComponent } from './all-projects-page/all-projects-page.component';
import { ResearchServicePageComponent } from './research-service-page/research-service-page.component';
import { ProjectPageComponent } from './project-page/project-page.component';
import { TeamPageComponent } from './team-page/team-page.component';
import { NewProjectComponent } from './new-project/new-project.component';
import { DigitalMarketingPageComponent } from './digital-marketing-page/digital-marketing-page.component';
import { ProjectResolver } from '../models/resolvers/project.resolver';

const routes: Routes = [
  { path: '', redirectTo: '/home', pathMatch: 'full' },
  { path: 'home', component: HomePageComponent},
  { path: 'about', component: AboutPageComponent},
  { path: 'blog', component: BlogPageComponent},
  { path: 'team', component: TeamPageComponent},
  { path: 'portfolio', component: AllProjectsPageComponent},
  { path: 'services', component: ServiceOverviewPageComponent},
  { path: 'project/:id', component: ProjectPageComponent, resolve: { project: ProjectResolver}},
  { path: 'brand-strategy', component: ResearchServicePageComponent},
  { path: 'digital-strategy', component: DigitalMarketingPageComponent},
  { path: 'custom-websites', component: BrandedWebsitesPageComponent},
  { path: 'web-apps', component: WebAppsPageComponent},
  { path: 'google-ads', component: GoogleAdsPageComponent},
  { path: 'web-design-development', component: WebServicesPageComponent},
  { path: 'search-engine-marketing', component: SEMPageComponent},
  { path: 'start-new-project', component: ContactPageComponent},
  { path: 'new-project', component: NewProjectComponent},
// post trial
  { path: 'posts/add', component: AddLeadPageComponent},
  { path: 'posts/add/:id', component: AddLeadPageComponent},
];

@NgModule({
  imports: [
            RouterModule.forRoot(routes, { scrollPositionRestoration: 'enabled'})
            ],
  exports: [RouterModule]
})
export class AppRoutingModule { }

1 Ответ

0 голосов
/ 11 января 2019

В вашем угловом коде нет ошибок. Проблема, с которой вы столкнулись, заключается в том, что URL не переписываются в index.html. Вам необходимо настроить это в настройках Firebase (firebase.json). Это самая простая и распространенная конфигурация:

  "hosting": {
    "public": "dist",
    "rewrites": [
      {
        "source": "**",
        "destination": "/index.html"
      }
    ]
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...