it-swarm.com.ru

Angular 4 - Прокрутка до якоря

Я пытаюсь сделать простой прокрутки до элемента привязки на той же странице. По сути, человек нажимает кнопку "Попробовать", и она прокручивается в область ниже на странице с идентификатором "логин". Сейчас он работает с базовым id="login" & <a href="#login"></a>, но переходит к этому разделу. В идеале хотелось бы там прокрутить. Если я использую Angular4, есть ли какие-то встроенные способы сделать это или какой самый простой способ? Спасибо!

Весь шаблон ... (компонент еще пуст)

<div id="image-header">
    <div id="intro">
        <h1 class="text-center">Welcome to ThinkPlan</h1>
        <h3 class="text-center">Planning your way</h3>
        <a class="btn btn-outline-primary" href="#login" id="view">Try It</a> <!-- Where the user clicks to scroll -->
    </div>
</div>
<div class="container" id="info">
    <div class="row">
        <div class="col-md-12">
             <div class="space" id="login"></div> <!-- The place to scroll to -->
                <h1 class="text-center">ThinkPlan</h1>
                <form  class="form-horizontal">
                    <fieldset>
                        <legend>Login</legend>
                        <div class="form-group">
                            <label for="inputEmail" class="col-lg-2 control-label">Email</label>
                            <div class="col-lg-10">
                                <input type="text" class="form-control" id="inputEmail" placeholder="Email">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="inputPassword" class="col-lg-2 control-label">Password</label>
                            <div class="col-lg-10">
                                <input type="password" class="form-control" id="inputPassword" placeholder="Password"> 
                            </div>
                        </div>
                        <div class="form-group" id="log-btn">
                            <div class="col-lg-10 col-lg-offset-2">
                                <button routerLink="/plan" type="submit" class="btn btn-outline-primary">Login</button>
                            </div>
                        </div>
                        <p class="lead text-center">New here? <a routerLink="signup">Sign up.</a></p>
                    </fieldset>
                </form>
        </div>
    </div>
</div>
9
lnamba

Я думаю, что это более простое решение:

В вашем HTML: 

<a [routerLink]="['/']" fragment="login"></a>

В вашем TypeScript:

ngOnInit() {
 this.route.fragment.subscribe(fragment => { this.fragment = fragment; });
}

ngAfterViewChecked(): void {
  try {
      if(this.fragment) {
          document.querySelector('#' + this.fragment).scrollIntoView();
      }
  } catch (e) { }
}
8
Sarah Dubois

Начиная с Angular v6, существует новая опция anchorScrolling для RouterModule. Вы можете установить его в модуле импорта:

imports: [
  ...,
  RouterModule.forRoot(routes, {anchorScrolling: 'enabled'})

При этом Angular автоматически прокрутит до элемента с идентификатором данного фрагмента.

Однако, это не работает, когда данные загружаются асинхронно, см. Эту проблему проблема Github .

Плавная прокрутка пока не возможна через RouterModule, но вы можете сделать это вручную: 

targetElement.scrollIntoView({behavior: "smooth"})
4
Kim Kern

С Angular 4 у вас могут возникнуть проблемы с использованием привязки к той же странице.

Я решил, используя этот способ

ng2-page-scroll

устанавливать

npm install ng2-page-scroll --save

импортировать в ваш app.module.ts

import {Ng2PageScrollModule} from 'ng2-page-scroll';

@NgModule({
    imports: [
        /* Other imports here */
        Ng2PageScrollModule
        ]
})
export class AppModule {
}

протестируйте его в своем HTML-компоненте

<a pageScroll href="#test">Testing</a>
<div id="test">
2
Gianluca Beritognolo

AfterViewCheck() будет вызываться каждый раз, когда запускается ChangeDetection, поэтому это плохое решение.

Используйте AfterViewInit() как

public ngAfterViewInit(): void {
  this.subscription = this.route.fragment
    .subscribe(fragment => {
        const targetElement = this.document.querySelector('#' + fragment);
        if (fragment && targetElement) {
            targetElement.scrollIntoView();
        } else {
            window.scrollTo(0, 0);
        }
    });
}
public ngOnDestroy(): void {
    this.subscription.unsubscribe();
}
0
Sergey Andreev