如何解决运行时错误:无效的内存地址或分页时取消了nil指针的引用
我正在尝试部分重写分页,但是编译时出现错误
目前,我正在像这样处理next
和prev
{{ if $paginator.HasNext }}
<li class="page-item">
<a class="page-link" href="{{ $paginator.Next.URL }}">
<i class="fal fa-chevron-right fa-xs"></i>
</a>
</li>
{{ end }}
我正在尝试对其进行修改,以便如果没有页面,则该按钮将被禁用而不是隐藏
<li class="page-item {{ if eq $paginator.HasNext false }}disabled{{ end }}">
<a class="page-link" href="{{ $paginator.Next.URL }}">
<i class="fal fa-chevron-right fa-xs"></i>
</a>
</li>
但是我得到了错误
错误2020/09/07 03:31:55无法呈现页面:“部分”的呈现失败:执行模板失败:模板:section / post.html:22:5:在
:调用Partial时出错:“ ../layouts/partials/pagination.html:75:56”:执行模板失败:template:partials / pagination.html:75:56:执行“ partials / pagination。 处的html”:调用URL错误:运行时错误:无效的内存地址或nil指针取消引用
完整代码段
{{ $paginator := .Paginator }}
<!-- Number of links either side of the current page. -->
{{ $adjacent_links := 2 }}
{{ $max_links := (add (mul $adjacent_links 2) 1) }}
{{ $lower_limit := (add $adjacent_links 1) }}
{{ $upper_limit := (sub $paginator.TotalPages $adjacent_links) }}
{{ if gt $paginator.TotalPages 1 }}
<nav aria-label="Page navigation example">
<ul class="pagination justify-content-center">
{{/* First */}}
<li class="page-item {{ if ne $paginator.PageNumber 1 }}disabled{{ end }}">
<a class="page-link" href="{{ $paginator.First.URL }}">
<i class="fal fa-chevron-double-left fa-xs"></i>
</a>
</li>
{{/* Prev */}}
{{ if $paginator.HasPrev }}
<li class="page-item">
<a class="page-link" href="{{ $paginator.Prev.URL }}">
<i class="fal fa-chevron-left fa-xs"></i>
</a>
</li>
{{- end -}}
{{/* Page # */}}
{{ range $paginator.Pagers }}
{{ $.Scratch.Set "page_number_flag" false }}
{{ if gt $paginator.TotalPages $max_links }}
{{ if le $paginator.PageNumber $lower_limit }}
{{ if le .PageNumber $max_links }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
{{ else if ge $paginator.PageNumber $upper_limit }}
{{ if gt .PageNumber (sub $paginator.TotalPages $max_links) }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
{{ else }}
{{ if and ( ge .PageNumber (sub $paginator.PageNumber $adjacent_links) ) ( le .PageNumber (add $paginator.PageNumber $adjacent_links) ) }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
{{ end }}
{{ else }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
{{ if eq ($.Scratch.Get "page_number_flag") true }}
{{ $isCurrent := false }}
{{ if eq . $paginator }}
{{ $isCurrent = true }}
{{ end }}
<li class="page-item {{ if $isCurrent }}active{{ end }}"
{{ if $isCurrent }}aria-current="page"{{ end }}>
<a class="page-link" href="{{ .URL }}">
{{ .PageNumber }}{{ if $isCurrent }}<span class="sr-only">(current)</span>{{ end }}
</a>
</li>
{{ end }}
{{ end }}
{{/* Next */}}
{{ if $paginator.HasNext }}
<li class="page-item">
<a class="page-link" href="{{ $paginator.Next.URL }}">
<i class="fal fa-chevron-right fa-xs"></i>
</a>
</li>
{{ end }}
{{/* Error here*/}}
<li class="page-item {{ if eq $paginator.HasNext false }}disabled{{ end }}">
{{ if $paginator.HasNext }}
<a class="page-link" href="{{ $paginator.Next.URL }}">
<i class="fal fa-chevron-right fa-xs"></i>
</a>
{{ end }}
</li>
{{/* Last */}}
<li class="page-item {{ if eq $paginator.PageNumber $paginator.TotalPages }}disabled{{ end }}">
<a class="page-link" href="{{ $paginator.Last.URL }}">
<i class="fal fa-chevron-double-right fa-xs"></i>
</a>
</li>
</ul>
</nav>
{{ end }}
解决方法
最终解决方案:
<li class="page-item {{ if not $paginator.HasNext }}disabled{{- end -}}">
<a class="page-link"
href="{{ if $paginator.HasNext }}{{ $paginator.Next.URL }}{{- else -}}#{{- end -}}">
<i class="fal fa-chevron-right fa-xs"></i>
</a>
</li>
我的问题是在调用{{ $paginator.Next.URL }}
之前没有安全检查,这导致nil
在最后一页呈现时出现。
看着resources/page/pagination.go
,我看到了:
// HasNext tests whether there are page(s) after the current.
func (p *Pager) HasNext() bool {
return p.PageNumber() < len(p.paginatedElements)
}
问题是您想要的(强调我的意思):
如果无页面,则该按钮被禁用而不是隐藏
所以p
可能是nil
。
您的{{ if gt $paginator.TotalPages 1 }}
的意思是:没有页面左。
但是,要进行测试,请尝试使用if eq $paginator.PageNumber $paginator.TotalPages
进行测试,并在这种情况下禁用该按钮。
检查paginator_test.go
是否有更安全的方法进行相同的测试。
OP在评论中指出:
我的问题是不了解编译器的工作方式。
像<li class="page-item {{ if $paginator.HasNext }}{{else}}disabled{{end}}"> <a class="page-link" href="{{ $paginator.Next.URL }}"> <i class="fal fa-chevron-right fa-xs"></i></a> </li>
将不起作用,因为在
$paginator.Next.URL
为$paginator.HasNext
(最后一页)的情况下正在调用false
。我最终使用了
{{else}}
语句
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。